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MICROCOMPUTER WITH PROGRAM-REVISION ABILITY 

BACKGROUND OF THE INVENTION 
1. Field o£ the Invention 
5 The present invention relates to a microcomputer with a 

program-revision ability, in which a program- storing memory 
cannot be easily removed from a substrate, especially a single 
chip microcomputer, in which all functional elements forming 
the microcomputer are integrally formed as a single chip, 
qjo 2 . Description of the Related Art 

As is well known, a microcomputer is representatively 
ij\ composed of a central processing unit (CPU) , a read-only 
£ memory (ROM) for storing various programs and constants, a 
j random^ access memory (RAM) for storing temporary data, and an 

: a,-srs, 

j;l5 input/output interface circuit (I/O) , and these elements are 
^ suitably arranged on and installed in a circuit board. In a 
Zl single chip microcomputer, the representative elements CPU, 
ROM, HAM and I/O are integrally formed as a single chip, anci 
the programs are previously stored in the ROM, in the course 
20 of production of the single chip microcomputer. Similarly, in 
a microcomputer in which the ROW cannot be easily removed from 
the circuit board, the programs are previously stored in the 
ROM in the course of production of the microcomputer. Thus, 
after the production of these microcomputers, a revision 
25 cannot be practically made in the programs stored in the ROM. 
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Accordingly, during the production of the microcomputer 
or after the production of the microcomputer , when it is found 
that a revision must be made in the programs stored in the 
ROM, the produced microcomputers axe obliged to be scrapped. 
5 Further, when the produced microcomputer is securely attached 
to an electronic product, this electronic product has to be 
scrapped. 

Note, as an example of the revision of the stored 

programs, there may be cases where bugs are found in one of 
10 the stored programs, where an alteration is made in one of the 

stored programs, and where an additional program is added to 

the stored programs . 
fx* On the contrary, in a microcomputer in which the ROM 

can be removably installed in a circuit board, it is possible 
|5 to easily make a revision in the stored programs, usin^j, for 
5i example, a ROM writer. Namely, the ROM is removed from the 

circuit board, and is then mounted in the ROM writer for 
P making tlie revision in the stored programs . After the 

revision is completed; the ROM is returned to and installed in 
20 the circuit board. 

Note, in this specif ication f the term "microcomputer" 

is referred to as representing a microcomputer, inclusive of a 

single chip microcomputer, in which the removal of the ROM 

cannot be easily performed, 
25 Conventionally, it is proposed that a microcomputer is 
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associated with an electrically erasable read-only memory 
(EEPROM) for the purpose of making a revision in programs 
previously stored in a ROM of the microcomputer as disclosed 
in, for example, U.S.. Patent No. 5,809,345* When a revision 
5 is made in the stored programs after the production of the 
microcomputer, a revisional program is written later in the 
EEPROM ♦ When the microcomputer is powered ON, the revisional 
program is read from the EEPROM, and is then stored in a 
predetermined address of a RAM of the microcomputer. During 

10 the execution of the programs of the ROM, an access is made to 
the predetermined address of the RAM, to thereby execute the 

uj revisional program, resulting in a virtual revision of the 

jji programs of the ROM. 

V; In particular, among the various programs stored in the 

%3 ROM, there may be a program which is susceptible to breeding 

v- of bugs and/ or there may be a program which needs in the 

-U future- In this case, a program-call instruction is 

w previously written in a head of tlae program concerned, and an 

address, corresponding to the program-call instruction, is 
20 previously set in the RAM. 

After the production of the microcomputer, when bugs 
are unfortunately found in the program concerned or when a 
revision must be made in the program concerned/ a revisional 
program is written and stored in the EEPROM. Whenever the 
25 microcomputer is powered ON, the revisional program is read 
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from the EEPROM, and is then stored in the previously-set 

address of the RAM. 

During the execution of the programs stored in the ROM; 

when the program-call instruction is read,, the execution of 
5 the programs of the ROM is once interrupted , and an access is 

made to the previously-set address of the RAM. If the 

revisional program is stored in the previously- set address of 

the RAM, the revisional program is executed , and the execution 

of the programs of the ROM is resumed after the execution of 
10 the revisional program is completed. On the other hand, if 
'Al the revisional program is not stored in the previously- set 

address of the RAM, the execution of the programs of the ROM 
m is iHuaediately resumed. Thus, it is possible to virtually 
'£ make the revision of the programs stored in the ROM. 
A5 Nevertheless, as is apparent from the foregoing, in the 

conventional method, a revision cannot be made at an optional 

location of the programs stored in the ROM, because a program- 
:J call instruction must be written in a head of a program 

previously selected from among the programs stored in ROM. 
20 Namely, it is impossible to make a revision in a program at a 

head of which the program-call instruction is not written. 

SUMMARY OF THE INVENTION 

Therefore, an object of the present invention is to 

provide a microcomputer with a program-revision ability, 
25 wherein a revision can be made in an optional location of 
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programs stored in a ROM thereof. 

In accordance with the present invention, there is 
provided a microcomputer including a read-only memory that 
stores programs, a controller/calculator that successively 
5 accesses to addresses of the programs stored in the read-only 
memory, to retrieve and decode an instruction from each of the 
accessed addresses, thereby executing a processing based on 
the decoded instruction, and a program counter in whieh an 
address to be accessed by the controller/calculator is 
VJO successively renewed and indicated. The microcomputer 
..V* comprises r at least one comparison-address- storage device that 
7" stores a comparison address data corresponding to an optional 
* address of the programs stored in the read-only memory, at 

'■: § i : 

which an interruption-processing should be executed to 
k 15 virtually revise the programs stored in the read-only memory; 
£ a random-access memory that stores a revisional program in 

□ which the interruption ^processing is programed; at least one 
vector~address-storage device that stores a vector addxess 
data corresponding to a head address of the revisional program 
20 stored in the random-access memory; and an address comparator 
that compares the comparison address data with an address 
successively renewed in the program counter. With this 
arrangement of the microcomputer, the controller/calculator 
makes an access to the head address of the revisional program, 
25 stored in the random-access memory, corresponding to the 
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vector address data stored in the vector-address-storage 
device, when it is determined by the address comparator that 
there is a coincidence between the comparison address data and 
the renewed address of the program counter, resulting in an 
5 execution of the interruption-processing in accordance with 
the revisional program. 

In an preferable embodiment of the invention, the 
microconqputer further comprises a discrimination system that 
discriminates whether the coincidence between the comparison 
fiO address data and the renewed address of the program counter is 
proper, and an address-coincidence-disabling system that 
disables the coincidence between the comparison address data 
*j and the renewed address of the program counter. 

Preferably, the microcomputer further comprises a 
pi 5 rewritable and non- volatile memory that stores the revisional 
f ; program, the comparison address data and the vector address 
p data, and a reading/ writing system that reads the revisional 
program, the comparison address data and the vector address 
data from the rewritable and non-volatile memory, and then 
20 writes these data in the random-access memory, the comparison- 
address -storage device and the vector-address-storage device, 
respectively, whenever the microcomputer is powered ON. 

In the microcomputer, the address comparator may be 
connected to the program counter, thereby retrieving the 
25 renewed address therefrom. Also, the address comparator may 
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be connected to an address bus extending to the program 
counter, to thereby retrieve the renewed address therefrom* 

The microcomputer may further comprise a vector-address 
data setting system that reads the vector address data from 
5 the vector-address-storage device, and that is then set in the 
program counter, whereby the access to the head address of the 
revisional program by the controller /calculator is made, 
resulting in the execution of the interruption-processing in 
accordance with the revisional program. 
f}0 The microcomputer may further comprises a vector- 

iifj address -temporary^ storage device that receives the vector 
7- address data from the vector-address -storage device, when it 
is determined by the address comparator that there is the 
coincidence between the comparison address data and the 
t 15 renewed address of the program counter, and a vector-address 

data setting system that reads the vector address data from 
r- the vector-address- temporary-storage device, and is then set 

in the program counter, whereby the access to the head address 
of the revisional program by the controller/calculator is 
20 made, resulting in the execution of the interruption- 
processing in accordance with the revisional program. 

The microcomputer may further comprise a return- 
address-setting system that sets the comparison address data 
as a return-address data in the program counter when the 
25 execution of the interruption-processing in accordance with 
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the revisional program is completed, and an address- 
coincidence-disabling system that disables the coincidence 
between the comparison address data and the return-address set 
in the program counter by the re turn-address- setting system. 
5 BRIEF DESCRIPTION OF THE DRAWINGS 

The object and other objects of the present invention 
will be better understood from the following description, with 
reference to the accompanying drawings , in which: 

Figure 1 is a block diagram of a microcomputer arranged 
10 according to the present invention; 

Figure 2 is a block diagram of a representative one of 
;n eight circuit elements included in an address -coincidence- 
interruption controller (ACIC) forming a part of a first 
embodiment of the microcomputer according to the present 
2.S invention; 

S Figure 3 is a view conceptually showing a memory area 

*J of an electrically erasable read-only memory (EEPROM) forming 
□ a part of the microcomputer according to the present 
invention ; 

20 Figure 4 is a view conceptually showing a comparison- 

address register (CAR) , an address-coincidence-interruption- 
allowing register (ACIAR) and a vector-address register (VAR) 
of a first circuit element; holding a comparison address data 
(CAO) a flag data (F£0) and a vector address data (VAO) , 

25 respectively; 

8 
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Figure 5 is a view conceptually showing a comparison- 
address register (CAR) , an address-coincidence-interruption- 
allowing register (ACIAR) and a vector-address register (VAR) 
of a second circuit element , holding a comparison address data 
5 (CAl) a flag data (FEl) and a vector address data {VAl) , 
respectively / 

Figure 6 is a view conceptually showing a comparison- 
address register (CAB.) , an address-coincidence-interruption- 
allowing register (ACIAR) and a vector-address register (VAR) 
10 o£ a third circuit element , holding a comparison address data 
(CA2) a flag data (FE2) and a vector address data (VA2) , 
respectively ; 

r ; Figure 7 is a view conceptually showing a comparison- 

V; address register (CAR) , an address -coincidence-interrupti on- 

allowing register (ACIAR) and a vector -address register (VAR) 
J; of a fourth circuit element, holding a comparison address data 
i, (CA3) a flag data (FE3) and a vector address data (VA3) , 

respectively ; 

Figure 8 is a view conceptually showing a comparison- 
20 address register (CAR) , an address-coincidence-interruption- 
allowing register (ACIAR) and a vector-address register (VAR) 
of a fifth circuit element, holding a comparison address data 
(CA4) a flag data (FE4) and a vector address data (VA4) , 
respectively ; 

25 Figure 9 is a view conceptually showing a comparison - 
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address register (CAR) , an address-coincidenee-interruption- 
allowing register (ACIAR) and a vector-address register (VAR) 
of a sixth circuit element, holding a comparison address data 
(CAS) a flag data (PES) and a vector address data (VA5) , 
respectively ; 

Figure 10 is a view conceptually showing a comparison- 
address register (CAR) , an address-coincidence-interruption- 
allowing register (AC1AR) and a vector-address register (VAR) 
of a seventh circuit element , holding a comparison address 
data <CA6) a flag data (FES) and a vector address data (VA6) , 
respectively ; 

Figure 11 is a view conceptually showing a comparison- 
address register (CAR) , an address-coincidence- interruption- 
allowing register (ACIAR) and a vector -address register (VAR) 
of an eighth circuit element, holding a comparison address 
data (CA7) a flag data (FE7) and a vector address data (VA7) , 
respectively; 

Figure 12 is a view conceptually showing a memory area 
of a random-access memory (RAM) forming a part of the 
microcomputer according to the present invention; 

Figure 13 is a view conceptually showing an address- 
coincidence-interruption-prohibiting register (ACXPR) , an 
address-coincidence-interruption-clearing register (ACICR) and 
an address-coincidence-interruption-monitoring register 
(ACXMR) of the first circuit element, holding flag data (FDO, 
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FCO and FMO) , respectively; 

Figure 14 is a view conceptually showing an address- 
coincidence-interruption-prohibiting register (ACIPR) , an 
address-coincidence-interruption-clearing register (ACICR) and 
an address-coincidence-interruption-monitoring register 
(ACIMR) of the second circuit element, holding £lag data (FDl, 
FC1 and FMl) , respectively ; 

Figure 15 is a view conceptually showing an address- 
coincidence-interruption-prohibiting register (ACIPR) , an 
address-coincidenee-interruption-elearing register (ACICR) and 
an address-coincidence-interruption-monitoring register 
(ACIMR) of the third circuit element, holding flag data (FD2, 
FC2 and FM2) , respectively; 

Figure 16 is a view conceptually showing an address- 
eoincidenee-interruption-prohiiiting register (ACIPR) , an 
address-coincidence-interruption-clearing register (ACICR) and 
an address-coincidence-interruptdon-monitoring register 
(ACIMR) of the fourth circuit element, holding flag data (FD3, 
FC3 and FM3) , respectively; 

Figure 17 is a view conceptually showing an address- 
coincidence-interruption-prohibiting register (ACIPR) , an 
address "Coincidence-interruption-clearing register (ACICR) and 
an address-coincidence-interruption-monitoring register 
(ACIMR) of the fifth circuit element, holding flag data (FD4 , 
25 FC4 and FM4) , respectively; 



4Cs 
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Figure 18 is a view conceptually showing an address- 
eoincidence-interruption-prohibiting register (ACIPR) , an 
address-coincidence-interruption-clearing register (ACICR) and 
an address-coincidence-interruption-monitoring register 
(ACIMR) of the sixth circuit element, holding flag data (FD5, 
FC5 and EMS) , respectively ; 

Figure 19 is a view conceptually showing an address- 
coincidence- interrupt ion-prohibiting register (ACIPR) , an 
address -coincidence-interruption-clearing register (ACICR) and 
an address-coincidence-interruption-monitoring register 
(ACIMR) of the seventh circuit element, holding flag data 
(FD6, FC6 and FM6) , respectively; 

Figure 20 is a view conceptually showing an address- 
eoineidence-interruption-prohibiting register (ACIPR) , an 
address-coincidence-interruption-clearing register (ACICR) and 
an address-coincidence-interruption-monitoring register 
(ACIMR) of the eighth circuit element, holding flag data (FD7 , 
FC7 and FM7) , respectively; 

Figure 21 is a flow chart of a sequential-interruption- 
transition processing executed by a control unit (CU) forming 
a part of the microcomputer according to the present 
invention ; 

Figure 22 is a wiring diagram of a reset circuit 
forming a part of the microcomputer according to the present 
invention; 
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Figure 23 is a timing chart of the reset circuit shown 
in Fig. 22; 

Figure 24 is a flow chart of a sequential-interruption- 
retum processing executed by the control unit (CTJ) of the 
5 microcomputer according to the present invention; 

Figure 25 is a wiring diagram of another reset circuit 
forming a part of the microcomputer according to the present 
invention ; 

Figure 26 is a timing chart of the reset circuit shown 
10 in Fig. 25; 

Figure 27 is a flow chart of a system operation routine 
for an electronic product, such as a printer, a video camera, 
a digital still camera, an electronic watch and so on, in 
which the microcomputer according to the present invention is 
is incorporated; 

% Figure 28 is a part of a processing-routine to be 

O executed in step 2709 of the system operation routine shown in 

h Fig. 27; 

Figure 29 is a view conceptually showing relationships 
20 between addresses successively renewed in a program counter 
forming a part of the microcomputer according to the pr^setnt 
invention and instructions executed in steps 2801 to 2810 of 
the processing- routine shown in Fig. 28; 

Figure 30 is a view conceptually showing a partial 
25 memory area of a read-only memory (ROM) forming a part of the 
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microcomputer according to the present invention; 

Figure 31 is a view conceptually showing a part of a 
program- storage area of the RAM; 

Figure 32 is a block diagram showing a modification of 
5 the representative one of the eight circuit elements included 
in the address-coincidence-interruption controller (ACIC) of 
the first embodiment of the microcomputer according to the 
present invention ; 

Figure 33 is a block diagram of a representative one of 
10 eight circuit elements included in an address -coincidence- 
interruption controller (ACIC) forming a part of a second 
embodiment of the microcomputer according to the present 
invention; 

Figure 34 is a flow chart of a sequential-interruption- 

15 transition processing executed by the control unit (CU) of the 
second embodiment of the microcomputer according to the 
present invention; 

I- Figure 35 is a view conceptually showing a partial 

memory area of the ROM of the second embodiment of the 

20 microcomputer according to the present invention; and 

Figure .36 is a block diagram showing a modification of 
the representative one of the eight circuit elements included 
in the address-coincidence-interruption controller (ACIC) of 
the second embodiment of the microcomputer according to the 

25 present invention. 
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DESCRIPTION OP. THE PREFERRED EMBODIMENTS 

Figure 1 shows a block diagram of a microcomputer with 
a program-revision ability, which is constructed a© a single 
chip microcomputer according to the present invention. 
5 The microcomputer comprises a central processing unit 

(CPU) 10, a read-only memory (ROM) 12 for storing various 
programs and constants, a random-access memory (RAM) 14 for 
storing temporary data, and an input/output interface circuit 
(I/O) 16 . The CPU 10 is connected to some pieces of 
10 peripheral equipment (not shown) via the I/O 16, so that 

various command signals and data signals are exchanged between 
01 tlie CU P 10 M( l the pieces of peripheral equipment. The CPU 10 
features an electrically erasable read-only memory (EEPROM) 
18, connected to the I/O 16, which stores various data for 
fS making revisions in the programs stored in the ROM 12, at 
U least one revisional program and/or at least one additional 
□ program, if necessary. Whenever the CPU 10 is powered ON 
O provided that the revisional program and/or the additional 

Program are stored in the EEPROM 18, these programs are read 
20 from the EEPROM 18, and then are written in the RAM 14. Each 
of the programs stored in the RAM 14 is suitably executed 
during an execution of the ROM-stored programs , as mentioned 
in detail hereinafter, 

As shown in Pig. 1, the CPU 10 includes a control unit 
>S (CU) 20, which is provided with a clock-pulse generator 22 and 
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a reset circuit 24, The clock-pulse generator 22 generates a 
series of basic clock pulses , and the CU 20 produces various 
kinds of control clock pulses , having different frequencies, 
based on the series of basic clock pulses. The various kinds 
5 of control clock pulses are used to control operations of 
various elements forming the CPU 10. The reset circuit 24 
outputs a reset signal to the CU 20 when the CPU 10 is powered 
ON, the various elements forming the CPU 10 are initialized. 
Also, the CPU 10 includes a program counter 26, an 

3 0 instruction register 28 and an instruction decoder 30, and the 
CU 20 operates in conjunction with these elements 26, 28 and 
30 so as to decode instructions successively read from the 

12 i ROM-stored programs, and outputs control signals to various 
elements forming the CPU 10 in accordance with the decoded 

fS instructions . 

In, particular, each of the ROM-stored programs is 
composed of a series of programed instructions, and each 

r ; instruction is stored in a given address of the ROM 12 . The 
CU 20 reads an instruction from an address of the ROM 12, 

20 which is indicated by the program counter 26- The read 

instruction is held, in the instruction register 28, and is 
decoded by the instruction decoder 30. Then, the CU 20 
outputs a control signal to one of the elements forming the 
CPU 10 in accordance with the decoded instruction, and a 

25 processing is executed in the element concerned of the CPU 10 
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based on the decoded instruction. As soon as the execution of 
the processing is completed, the address, indicated by the 
program counter 26, is incremented by, for example, "1*, 
resulting in renewal of the address, from which an instruction 
5 should be read by the CU 20. In this embodiment, each address 
of the ROW 12 is composed of 16 bits, and the program counter 
is formed as a 16-bit register* 

Further, the CPU 10 includes an arithmetic logic unit 
(ALU) 32, a temporary register 34, an accumulator 36 and a 
10 status register 38. The ALU 32 executes a binary operation on 
D the basis of a control signal output from the CU 20, in 

conjunction with the temporary register 34, the accumulator 36 
and the status register 38. 
Sj Binary data to be processed by the binary operation are 

15 suitably retrieved by the ALU 32 from the temporary register 
J; 34 and the accumulator 36. For example, constant data read 
k; from the ROM 12 or temporary data read from the RAM 14 is held 
C *>y th* temporary register 34, and is retrieved by the ALU 32 

from the temporary register 34, whereby the data is processed 
2 0 by the binary operation executed by ALU 32. The processed 

data or resultant data is input to the accumulator 36 having a 
calculation-function. Namely, the resultant data, input to 
the accumulator 36, is processed by the calculation-function 
thereof, and is held in the accumulator 36. Also, the data is 
25 suitably retrieved by the ALU 32 from the accumulator 36, if 
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necessary . 

The status register 38 holds various pieces of status- 
inform^tion as flag data, representing statuses of the binary 
operation executed by the ALU 32, Namely, for example, a 
5 carry flag, an overflow flag, a zero flag, a sign flag and so 
on are held by the status register 38 for the representation 
of the statuses of the binary operation executed by the ALU 
32. 

Also, the status register 38 holds an interruption - 
10 allowing flag, which is initialized to be "0* when the CPU 10 
4? is powered ON. When the interruption-allowing flag is made to 
CP be m l", various interruptions are allowed in the CPU 10, When 
ill the interruption -allowing flag is "0", all the interruptions 
fy are prohibited except for a non-maskable interruption (MMI) 
Xj5 and a software interruption . 

J5 As shown in Pig, 1, the CPU is further provided with an 

interruption controller 40, a general purpose register 42 and 
U a stack pointer 44. The interruption controller 40 controls 
an execution of an interruption-processing or subroutine based 

20 on an interruption signal output from either the CU 20 or a 

piece of peripheral equipment (not shown) connected to the I/O 
16. The general purpose register 42 is utilized as a multi- 
purpose register. Namely, the general purpose register 42 is 
sectioned into some areas, each of which is defined as, for 

25 example, an accumulator, an index register, a stack memory or 
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the like. The stack pointer 44 is formed as a register for 
indicating an address of the stack memory; defined in the 
general purpose register 42, from which data should be read. 
For example, the stack memory holds a return- address which 
5 should 1m accessed after an execution of an interruption- 
processing or subroutine is completed. 

Note, in Fig. 1, reference 46 indicates a multiplexer, 
which is used to distribute control signals and data to the 
interruption controller 40, the general purpose register 42 
10 and titxe stack pointexr 44. 

"™ Although the aforementioned elements of the CPU 10 are 

well known in this field, the CPU 10 features a novel element, 
4; which is referred to as an address-coincidence-interruption 
fii controller (ACIC) 48 constructed according to the present 
1l5 invention . 

m In a first embodiment of the present invention, the 

ACIC 48 comprises eight circuit elements, only one of which is 
jr; representatively shown in Fig. 2, and is generally indicated 
by reference 48 n (n = 0, 1, ... 6 and 7). Of course, the circuit 

20 elements 48 n are substantially identical to each other. The 
number of the circuit elements 48 n corresponds to a number of 
optional locations, at each of which the ROM-stored programs 
should revised. Thus, in this embodiment, it is possible to 
revise the ROM-stored programs at eight optional locations 

25 thereof, as stated in detail hereinafter. 
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As shown in Fig- 2, each circuit elements 48 n includes 
a coxnpari son-address register (CAR) 50, which is initialised 
when the CPU 10 is powered ON, and which is suitably connected 
to the elements of the microcomputer via a control bus, an 
address bus and a data bus. The CAR 50 is formed as a 16-bit 
register, the bit-number of which is equal to that of an 
address of the ROM 12* In each of the eight circuit elements 
48 n , a given address is written in the CAR 50, if necessary. 

For example, when it is found that bugs are included in 
one of the ROM-stored programs, a head address of the program 
including the bugs is written in the CAR 50 . If an additional 
program should be added at a location of the programs stored 
in the ROM 12, an address corresponding to that location is 
written in the CAR 50. Note, the writing of an address in the 
CAR 50 is explained in detail hereinafter. 

As shown in Fig, 2, the CAR 50 is connected to an 
address comparator 52 via a bus, and the program counter 26 is 
connected to the address comparator 52 via a bus . As stated 
above, while the ROM-stored programs are executed, an address 
is successively renewed in the program counter 26, Whenever 
the address is renewed, a renewed address is compared with the 
address, held in the CAR 50, by the address comparator 52. Of 
course, the respective comparisons of the renewed addresses 
with the addresses held in the CAR's 50 of the circuit elements 
48 n are simultaneously performed* 
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The address comparator 52 has an output terminal, which 
is connected to one of two input terminals of an AND-gate 54, 
and an output level of the address comparator 52 to the AND- 
gate 54 is usually a low level. When the renewed address of 
5 the program counter 26 coincides with the address held in the 
CAR 50, the output level of the address comparator 53 is 
changed from the low level to a high level. Namely, when 
there is a coincidence between the renewed address of the 
program counter 26 the address of the CAR 50, an address- 
10 coincidence (AC) signal is output as the high level signal 
% Z from the address comparator 52. Note, when the CPU 10 is 

powered ON, the address comparator 52 is initialized such that 
III the low level signal is output from the address comparator 52. 
R| As shown in Fig. 2, the other input terminal of the 

» 15 AND-gate 54 is connected to an output terminal of an inverter 
m 56, and an input terminal of the inverter 56 is then connected 
~f to an output terminal of an address-coincidence-interruption- 
2 prohibition register (ACIPR) 58. The ACIPR 58 is formed as a 
1-bit register, and is suitably connected to the elements of 
20 the microcomputer via a control bus, an address bus and a data 
bus. A setting of *0" is usually given to the ACIPR 58, so 
that an output level of the ACIPR 58 to the inverter 56 is a 
low level* However, when a setting of "1" is given to the 
ACIPR 58, the output level of the ACIPR 58 is changed from the 
25 low level to a high level. In short, the 1-bit data of the 



21 



from mm ' * 20m m 3B(« \\:2o/m\\:wmm^\ mm p 23 

ACIPR 58 is usually "0", and thus a high level signal is output 
from the inverter 56. When the 1-bit data of the ACIPR 58 is 
changed from "0" to "1", a low level signal is output from the 
inverter 56- Note, the change of the 1-bit data of the ACIPR 
5 56 from u 0" to "l" is explained in detail hereinafter. 

The ACIPR 58 is associated with a reset circuit 60, 
which is provided for returning the 1-bit data of the ACIPR 58 
from - 1* to M 0 W whenever the 1-bit data of the ACIPR 58 is 
changed from "0" to *l" . Namely, after the 1-bit data of the 
10 ACIPR 58 is changed from "0" to "1* , when a reset signal RE1 is 
output as a high level signal from the reset circuit 60 to the 
ACIPR 58, the 1-bit data of the ACIPR 58 is returned from *1" 

Y Not only the address-coincidence (AC) signal is input 

7 *15 from the address comparator 52 to the reset circuit 60, but 
!r also a series of system clock pulses for controlling timings 
£: of various operations of the CPU 10 is input to the reset 
|i; circuit 60- The reset eircuit 60 produces the reset signal 

RE1 based on the AC signal and the system clock pulses as 
20 stated in detail hereinafter. Note, the reset circuit 60 is 

initialized by a reset signal input thereto when the CPU 10 is 

powered ON- 

As shown in Pig. 2, an output terminal of the AND-gate 
54 is connected to an input terminal C of a flip-flop 62, and 
25 a high level signal is always input to an input terminal D of 
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the flip-flop 62 after the CPU 10 is powered OH. When the 
address-coincidence (AC) signal is output from the address 
comparator 52 provided that the high level signal is output 
from the inverter 56, the AND-gate 54 outputs a high level 
5 signal from the output terminal thereof to the input terminal 
C of the flop-flip 62. At this time, an address-coincidenee- 
intarruption-requiring (ACIR) signal is output as a high level 
signal from the output terminal Q of the flop-flip 62. 

The output terminal Q of the flop-flip 62 is connected 
10 to an input terminal of an address-coincidence-interruptxon- 
% monitoring register (ACIMR) 64. Similar to the ACIPR 58, the 
ACIMR 64 is formed as a 1-bit register, and is suitably 
connected to the elements of the microcomputer via a control 
bus, an address bus and a data bus. A 1-bit data of the ACIMR 
«' 15 64 is initialized to be "0" by a reset signal input thereto 

when the CPU 10 is powered ON. When the address -coincidence- 
2 interruption-requiring (ACIR) signal (high level) is output 
% from the output terminal Q of the flop-flip 62, the 1-bit data 
of the ACIMR 64 is changed from "0" to "1". When the outputting 
20 of the ACIR signal comes to a standstill, i.e. when the output 
level of the output terminal Q of the flop-flip 62 is changed 
from the high level to the low level, the 1-bit data of the 
ACIMR 64 is returned from "1" to *0\ In short, by reading the 
1-bit data from the ACIMR 64, it is possible to determine 
25 whether the ACIR signal is output from the output terminal Q 
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of the flop-flip 62. 

As shown xn Fig. 2, the output terminal Q of the flip- 
flop 62 is connected to one of two input terminals of an AND- 
gate 66, and the other input terminal of the AND-gate 66 is 
5 connected to an output terminal of an address-coincidence- 
interruption-allowing register (ACIAR) 68. The ACIAR 68 is 
also formed as a 1-bit register, and is suitably connected to 
the elements of the microcomputer via a control bus , an 
address bus and a data bus. A 1-bit data of the ACIAR 68 is 
10 initialized to be "0* by a reset signal input thereto when the 
£j CPU 10 is powered ON. When a setting of u l" is given to the 
LJ ACIAR 68, a high level signal is output from the output 

terminal of the ACIAR 68, and is then input to the other input 
|; terminal of the AND-gate 66. When a setting of "0" is given to 
!t ^ he ACIAR 68, a low level signal is output from the output 
m terminal of the ACIAR 68, and is then input to the other input 
|j terminal of the AND- gate 66. 

C Thus, when the setting of "1" is given to the ACIAR 68, 

and when the address -coincidence-interruption-requiring (ACIR) 

20 signal is output from the output terminal Q of the flip-flop 
62, the high level signals are input to both the input 
terminals of the AND -gate 66, whereby an address-coincidence- 
interruption (AC1) signal is output as a high level signal 
from an output terminal of the AND-gate 66 to the interruption 

25 controller 40, When the ACI signal is input to the 
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interruption controller 40, an interruption-processing is 
executed in the CPU 10, as explained in detail hereinafter. 

As is apparent from Fig. 2, the address-coincidence- 
interruption -signal (AC I) is also input from the AND-gate 66 
5 to a vector- address register (VAR) 70. The VAR 70 is 

initialized by a reset signal input thereto when the CPU 10 is 
powered ON, and is suitably connected to the elements of the 
microcomputer via a control bus, an address bus and a data 
bus. Similar to the CAR 50, the VAR 70 is formed as 16-bit 

10 register, the bit-number of which is equal to that of an 

y address of the ROM 12. 

In each of the eight circuit elements 48 ft/ a given 
m vector address is written in the VAR 70, if necessary. A 
m vector address to be written in each VAR 70 corresponds to a 
X L head addxess o£ a Program stored in the RAM 14. Note, when 
| the CPU 10 is powered ON provided that a revisional program 
g and/or an additional program are stored in the EEPROM 18, 
| these programs are read from the EEPROM 18, and are written in 
RAM 14, as mentioned above. 

20 '* tl * n the ade *«*ss-coincidence-interruption (ACI) signal 

is input from the AND -gate 66 to the VAR 70, the vector 
address is output from the VAR 70 to the program counter 26, 
and is then written therein. Note, the writing of a vector 
address in each VAR 70 is explained in detail hereinafter. 

25 After the address-coincidence-interruption-requiring 



25 



FROM IM ' f 2000$ 8fl 3B it) 11 : 20/1111 :16/JW4801 158873 P 27 



(ACIR) signal is output from the output terminal Q of the 
flip-flop 62, a reset signal RE2 is output as a high level 
signal from a reset circuit 72 to a reset terminal R of the 
flip-flop 62, so that the flip-flop 62 is unlatched, whereby 
5 the outputting of the ACIR signal comes to a standstill . 

Namely, due to the outputting of the reset signal RE2 from the 
reset: circuit 72 -to the reset terminal R of the flip-flop 62, 
the output level of the output terminal Q of the flop-flip 62 
is returned from the high level to the low level. 
10 ** shown in Fig. 2, the reset circuit 72 is associated 

i with 8X1 ad OX®ss-coincidence-interruption-elearing register 
J; <ACXCR) 74, which produces and outputs a clear signal CI to 
% the reset circuit 72. Further, the aforesaid system clock 
Rj pulses are input to the reset circuit 72. The reset signal 
^5 RE2 is produced based on the clear signal cl and the system 
g clock pulses as stated in detail hereinafter. Note, the reset 
| circuit 72 is initialized by a reset signal input thereto when 
the CPU 10 is powered ON. 

The ACICR 74 is also formed as a 1-bit register, and is 
20 suitably connected to the elements of the microcomputer via a 
control bus, an address bus and a data bus. A setting of «0" 
is usually given to the ACICR 74, but the 1-bit data of the 
ACICR 74 is changed from "0" to "1" after the address- 
coincidence-interruption (ACI) signal is input from the AND— 
25 gate 66 to the interruption controller 40. At this time, the 
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clear signal CL is output as a high level signal from the 
ACICR 74 to the reset circuit 72 « Note, the setting of 1-bit 
data to be given to the ACICR 74 is explained in detail 
hereinafter . 

5 When, the flip-flop 62 is unlateh&d due to the inputting 

of the reset signal RE2 from the reset circuit 72 to the flip- 
flop 62, a reset signal RE3 is output from the reset circuit 
72 to the ACICR 74, whereby the 1-bxt data of the ACICR 74 is 
returned from u l w to "0", so that the outputting of the clear 
10 signal CL from the ACICR 74 to the reset circuit 72 comes to a 
W standstill. Namely, the output level of the ACICR 74 to the 
m rest circuit 72 is returned from the high level to the low 
level* Note, similar to the reset signal RE2 , the reset 
signal RE3 is produced based on the clear signal CL and the 
fS system clock pulses as stated in detail hereinafter. 
;I In t* 1 * first embodiment, the EEPROM 18 stores eight 

U compari son-address data, eight flag data, and eight vector- 
D address data. Whenever the CPU 10 is powered ON, the eight 
comparison-address data, eight flag data, and eight vector- 
20 address data are read from the EEPROM 18, and are written in 
the CAR's 50, ACIAR's 68 and VAR's 70 of the eight circuit 
elements 48 n , respectively. Further, as already stated, if 
necessary , the EEPROM 18 stores a revisional program and/or an 
additional program for making revisions in the ROM- stored 
25 programs, and these programs are stored in the RAM 14 whenever 
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the CPU 10 is powered ON. 

When the EEPROM 18 is securely installed in the 
microcomputer, i.e. when the EEPROM 18 cannot be removed from 
the microcomputer, the aforesaid various data and programs are 
5 written in the EEPROM 18 / using an EEPROM-writing computer 

(not shown), which is connected to the microcomputer (Fig. 1). 
Namely , the writing of the various data and program in the 
EEPROM 18 is performed by the EEPROM-writing computer through 
the CPU 10 of the microcomputer . Of course , in this case, an 
10 EEPROM-writing program is previously stored in the ROM 12. 

On the other hand, when the EEPROM 18 is removably 
installed in the microcomputer/ the EEPROM 18 is once removed 
1 from the microcomputer, and is then mounted in an EEPROM- 
writing computer (not shown) for writing the various data and 
15 programs in the EEPROM 18. After the writing of the various 
Bj data and program in the EEPROM 18 is completed, the EEPROM 18 
is removed from the EEPROM-writing computer , and is then 
returned to the microcomputer. Of course, in this case, the 
storage of the EEPROM-writing program in the ROM 12 is 
2 0 unneces sary . 

Referring to Fig. 3, a memory area of the EEPROM 18 is 
conceptually illustrated. As shown in this drawing, the 
EEPROM 18 includes eight comparison-address -storage zones 
CAZO, CAZl, - C&Z6 and CAZ7 , in which comparison-address data 
25 CA0tCA0 00 , CM 0l , - CA0 14 , CA0 15 ] ; CAltCAl 00 , C*l 01 , - CAl l4 , 
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CA1 XS ]; CA6tCA6 00/ CA6 01 , »• CA6 14 , CA6 15 ] and CA7[CA7 Q0 , 
CA7 01 , - CA7 i4/ C^is 1 are stored, respectively. Also, the 
EE PROM 18 includes eight vector-address-storage zones VAZO, 
VAZ1, »< VAZ6 and VAZ7, in which vector-address data VAO[VA0 00 , 
5 VAO Q1 , » VA0 14f VA0 15 ]; VAl[VAl 00 , VAl 01 , >~ VAl 14 , VAl 15 l ; - 

VA€[VA6 00 , VA6 Q1 , - VA6 14 , VA6 15 J and VA7[VA7 0Q/ VA7 Q1/ - VA7 14 , 
VA7 X5 ] are stored, respectively. Of course, as stated above, 
each of the comparison-address data CAO, CA1, - CA6 and CA7 is 
formed as a 16-bit data, and each of the vector-address data 
10 VAO, VAl, - VA6 and VA7 is also formed as a 16-bit data. The 
yg EEPRQM 18 further includes eight flag-data- storage zones in 

which flag data FEO , FEl , FK6 and FE7, respectively, each of 
7n which is, of course, formed as a 1-bit data. Note, the 

respective comparison-address data CAO, CA1, - CA6 and CA7 
^15 correspond to the vector-address data VAO, VAl, «■ VA6 and VA7, 
Vr and also correspond to the flag data FEO, FEl, ■* FE6 and FE7- 
%! Furthermore, the EE PROM 18 includes a program- storage 

C: area and a data-storage area. In the program-storage area, if 

necessary, a revisional program and/or an additional program 
20 is stored for making revisions in the ROM-stored programs. 
Also, the data-storage area is used to store various data, 
such as correction data, for an electronic product, such as an 
electronic camera, a video camera, a printer or the like, in 
which the microcomputer (Fig, 1) is incorporated. 
25 A first example of revision of the ROM-stored programs 



29 



FROM W&m ' " 2000f m 3B OW 1 1 : 21/«1 1 : 1 6/WiS4801 1 58873 P 31 

t 

is directed to a case where one of the ROM-stored programs 
includes bugs- In this first example, a revisional or proper 
program, which should be substituted for the program including 
the bugs, is prepared and stored in the program- storage area 
5 of the EEPROM 18 (Fig. 3), and an address, in which an 

instruction for leading an execution of the program including 
the bugs is stored/ is written as a comparison address data in 
one of the comparison-address-storage zones CA20, CAZl, - CAS 6 
and CAZ7 of the EEPROM 18 (Fig. 3) . Also, an address of the 
10 RAM 14, at: which a first instruction of the proper program 
dg should be stored , i.e. a head address of the proper program, 
is written as a vector address data in a vector-address- 
storage zone (VAZO, VAZl, - VAZ$, VAZ7) , corresponding to the 
comparison-address-storage zone (CAZO, CAZl , .« CAZ6, CAZ7) in 
*15 which the comparison address data is written. Further, a 
K setting of *1" is given to a flag data (FEO, FEl, - FE6, FE7) , 
£ corresponding to the compar is on -address -storage zone (CAZO, 
? g CAZl, - CAZ6, CAZ7) in which the comparison address data is 
written. For example, when the comparison address data is 
20 written in the comparison-address- storage zone CAZO, the 

vector address data is written in the corresponding vector- 
address-storage zone VAZO, and the setting of "1" is given to 
the corresponding flag data FEO. 

Note, the address of the RAM 14, at which the first 
25 instruction of the proper program should be stored/ is 
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referred to as a head address of the proper program, 
hereinafter , 

A second example of revision of the ROM-stored programs 
is directed to a case where an additional program is added to 
the ROM- stored programs at an optional location thereof . In 
this second example , an additional program, which should be 
added to the ROM-stored programs, is prepared and stored in 
the program- storage area of the EEPRGM 18, and an address, 
corresponding to that location of the ROM-stored programs, is 
written as a comparison, address data in one of the comparison- 
address-storage zones CAZO, CAZ1, •» CA26 and CAZ7 of the EEPROM 
18. Also, an address of the RAM 14, at which a first 
instruction of the additional program should be stored, is 
written as a vector address data in a vector-address-storage 
zone (VAZO, VAZ1, »- VAZ6, VAZ7) , corresponding to the 
coarparison-address-storage zone (CAZO, CAZ1, - CAZ6, CAZ7) in 
which the comparison address data is written. Further, a 
setting of "1" is given to a flag data (FEO, FE1 , •» fes, FE7) , 
corresponding to the comparison-address-storage zone {CAZO, 
CAZ1, -« CAZ6, CAZ7) in which the comparison address data is 
written* For example , when the comparison a.dd^&ss data is 
written i» the comparison- address-storage zone CAZ1, the 
vector address data is written in the corresponding vector- 
address-storage zone VAZ1, and the setting of *l w is given to 
the corresponding flag data FE1 . 
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Uote, the address of the RAM 14, at which the first 
instruction of the additional program should be stored/ is 
referred to as a head address of the additional program, 
hereinafter , 

5 A third examplo of revision of the ROM-stored programs 

is directed to a case where one of the ROM- stored programs is 
executed at another optional location thereof. In this third 
example, a call program for calling the program concerned of 
the ROM- stored programs is prepared and stored in the program- 
10 storage area of the EEPROM 18 , and an address , corresponding 
£ to that location of the ROM-stored programs, is written as a 
comparison address data in one of the comparison-address- 
storage zones CAZO, CAZ1, - CAZ6 and CAZ7 of the EEPROM 18, 
"£:■ Also, an address of the RAM 14, at which a first instruction 
p?5 of the call program should be stored/ is written as a vector 
address data in a vector-address-storage zone (VAZO, VAZl, -» 
VAZ6, VA27) , corresponding to the comparison-address-storage 

: L„-" 

C zone (CAZO, CAZ1, - CA26, CAZ7) in which the comparison address 
is written. Further, a setting of "1* is given to a flag data 

20 (FEO, FE1, * FE6, FB7) , corresponding to the comparison- 
address -storage zone (CA20, CAZ1, - CAZ6, CAZ7) in which the 
comparison address data is written. For example, when the 
comparison address data is written in the conqparison-address- 
storage zone CA22 , the vector address data is written in the 

25 corresponding vector-address -storage zone VAZ2, and the 
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setting of "1" is given to the corresponding flag data FE2 . 

Note, the address of the MM 14, at which the first 
instruction of the call program should be stored, is referred 
to as a head address of the call program, hereinafter. 
5 Each of the flag data FEO, FBI, - FES and FE7 is 

utilized to discriminate whether a comparison address stored 
in a corresponding comparison-address-storage zone (CAZO, 
CAZ1, CAZ6, CAZ7) and a corresponding vector-address-storage 
zone {VAZO, VAZ1, VAZ6, VAZ7) participate in an actual 
10 revision of the ROM-stored programs. Thus, when the aforesaid 
; g three examples are incorporated in the ROM- stored programs, 
ll the setting of "1" is given only to the three flag data FEO, 

FBI and FE2 , because the corresponding comparison address data 
CAO , CA1 and C&2 and the corresponding vector address data 
nb VAO, VA1 and VA2 participate in the actual revisions of the 
5; ROM-stored programs. In this case, the comparison address 
|J data and a setting of "0* is given to the remaining flag data 
^; FE3, FE4, - FES and FE7, because a certain data stored as a 

comparison address data (C&3, CA4, - CA6, CA7) in each 
20 comparison-address-storage zone (CA23, CAZ4 , » CAZ6, CAZ7) and 
a certain stored as a vector address data (VA3, VA4, - VA6, 
VA7) in each vector-address-storage «one (VAZ3, V3VZ4, - 
VAZ7) participate in no actual revision of the ROM-stored 
programs . 

25 As already stated hereinbefore, whenever the CPU 10 is 
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powered ON, the comparison address data CAO, CAl, - CA6 and CA7 
are read from the comparison-address-storage zones CAZO, CAZ1, 
CAZ6 and CAZ7 of the EE PROM 18, and are then written in the 
CAR's 50 of the circuit elements 48^, respectively, whether 
5 each comparison address data participates or not in an actual 
revision of the ROM~stored programs. Similarly, whenever the 
CPU 10 is powered OK, the vector address data VAO, VA1, - VA6 
and VA7 are read from the vector-address-storage zones VAZO, 
VAZ1, »- VAZ6 and VAZ7 of the EEPROM 18, and are then written in 
10 the VAR's 70 of the circuit elements 48 n , respectively. Also, 
% whenever the CPU 10 is powered ON, the flag data FEO, FE1, »■ 
FE6 and FE7 are read from the EEPROM 18, and are then written 
in the ACIAR's of the circuit elements 48 n , respectively. 
Ill Referring to Figs. 4 to 11, the CAR 50, AC TAR 68 and 

1$ VAR 70 of each circuit element (48 n ) , holding the corresponding 
rg comparison address data (CAO , CAl, ... CA6, CA7) , flag data (FEO, 

FE1, ~ FE6, FE7) , and vector address data (VAO, VA1 , • VA6, 
if VA7 > ^ respectively, are conceptually shown. As stated above, 
When the aforesaid revision examples are incorporated in the 
20 ROM-stored programs, the comparison address data CAO, CAl and 
CA2 and vector address data CAO , VA1 and VA2 participate in 
the actual revisions of the ROM-stored programs, and thus the 
flag data FEO, FBI and are "1" (Figs. 4, 5 and 6) . On the 

other hand, the comparison address data CA3, CA4 , CA6 and CA7 
25 and vector address data VA3, VA4, ... VA6 and VA7 participate in 
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no actual revision of the ROM-stored programs , and thus the 
flag data FE3, FE4, -» FE6 and FE7 are a (T (Figs. 7, 8, 9, 10 
and 11) . In short, due to the value ("1" ox M 0") of each flag 
data (FEO, FE1, - FE6, FE7) , it is possible to discriminate 
5 whether both a comparison address data and a vector address 
data, corresponding to the flag data concerned, participate or 
not in an actual revision of the ROM-stored programs. 

Also, ±n the case where the aforesaid revision examples 
are incorporated in the ROM-stored programs, whenever the CPU 
10 10 is powered ON, the revisional, additional and call programs 
U are read from the program- storage area of the EE PROM 18 , and 
yl are then written in the RAM 14- Of course, at this time, the 
||1 various data, such as the correction data, for the electronic 

Product in which the microcomputer (Fig. 1} is incorporated, 
15 are read from the data-storage area of the EEPROM 18, and are 
}2 then written in the RAM 14. 

Referring to Fig, 12, a memory area of the RAM 14 is 
conceptually illustrated. As shown in this drawing the RAM 14 
includes a program-execution-working area, a data-storage 
2 0 area, a program-storage area and a stack memory area defined 
therein. The program-execution-working, area is utilized to 
store, for example, various temporary data which are produced 
during an execution of the ROM-stored programs. The data- 
storage area is provided for storing the various data read 
25 from the data-storage area of the EEPROM 18, The program- 
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storage area is provided for the re visional, additional and 
call programs read from the program-storage area of the EE PROM 
18 . The stack memory area is utilized as a working area for 
storing, various data to be processed later during the 
5 execution of the ROM-stored programs - 

Referring to Figs. 13 to 20, the ACIPR's 58, ACICR's 74 
and ACIMR's 64 of the circuit elements 48 n are conceptually 
shown , and each of these registers 58, 74 and 64 is formed as 
the 1-bit register as mentioned above, 
1° Flag data FDO, FD1 , «- FD6 and FD7 are defined in the 

0 ACIPR's 58 of the circuit elements 48 n , respectively, and are 

01 initialized to be "0* when the CPU 10 is powered ON. A setting 
of "1" is suitably given to each flag data (£T>0, FBI, ... FD6, 
FD7) according to an aspect of operation of the CPU 10. 

^5 Also, flag data FCO, FC1, «■ FC6 and FC7 are defined in 

the ACICR's 74 of the circuit elements 48 n , respectively, and 
aare "^tialized to be "0" when the CPU 10 is powered ON. A 

C setting of "1" is suitably given to each flag data (FCO, FC1, - 

FC6, FC7) according to an aspect of operation of the CPU 10. 
20 Further,, flag data FMO, FM1, - sw6 and FM7 are defined 

in the ACXMR's 64 of the circuit elements 48 n , respectively, 
and are initialized to be "0" when the CPU 10 is powered ON, A 
setting of a l" is suitably given to each flag data (FMO, FM1, ~ 
EW6, FM7) according to an aspect of operation of the CPU 10. 
25 already stated, during an operation of the CPU 10, 
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an address is successively renewed in the program counter 26. 
In each of the circuit elements 48 n , a corresponding address 
comparator 52 retrieves the successively-renewed address from 
the program counter 26, and compares the retrieved address 
5 with a comparison address data (CAO, CAl, - CAS, CA7) held in 
the corresponding CAR 50, When there is a coincidence between 
the retrieved address and the comparison address data held in 
one of the eight CAR'S 50, an address-coincidence (AC) signal 
is output as a high level signal from the address comparator 
10 52. 

yg For example, when the retrieved address coincides with 

the comparison address data CAO held in the CAR 50 of the 
circuit element 48 Q/ the address -coincidence (AC) signal is 
output from the address comparator 52 of the circuit element 

*15 48 0 , and is then input to one of the two input terminals of the 
AND-gate 54 of the circuit element 48 Q . On the other hand, a 
high level signal is output from the output terminal of the 

PI inverter 56 to the other input terminal of the AND-gate 54, 
due to the initial setting of "0" given to the flag data FDO 

20 defined in the ACIPR 58 of the circuit element 48 0 - In short, 
when the AC signal is output from the address comparator 52, 
the output level of the AND-gate 54 is changed from the low 
level to the high level, and this high level signal is input 
to the input terminal C of the flip-flop 62 . 
2 5 As stated hereinbefore, the high level signal is always 

37 



from mm 



20m ffl 3B(*) 11 : 22/111 1:16/^4801 158873 P 39 



input to the input terminal D of the flip-flop 62. Thus, when 
the AC signal is output from the address comparator 52, an 
address-coincidence-interruption requiring (ACIR) signal is 
output as a high level signal from the output terminal Q of 
5 the flip-flop 62 to one of the input terminals of the AND-gate 
66. 

When the aforesaid revision examples are incorporated 
in the ROM-stored programs, the comparison address data CAO , 
CA1 and GA2, held in the CAR's 50 of the circuit elements 48 Q/ 
10 48^^ and 48 2 , respectively, participate in the actual revisions 
*K of the ROM-stored programs, and the setting of a l n is given to 

the corresponding flag data FEO, FEl and F£2 , Thus, in each 
[f; of the circuit elements 48 Q , 48 1 and 48^, an address- 
,1 coincidence-interruption-allowing (ACIA) signal is output as a 
Ll5 high level signal from the ACXAR 68. 

^ Accordingly, in each of the circuit elements 48 0/ 4& 1 

*y and 48 2 , when an address retrieved from the program counter 26 
Q coincides with a comparison address data (CAO, CA1, CA2) held 
in the CAR 50, i,e* when an address -co incidence (AC) signal is 
20 output from the address comparator 52, an address-coincidence- 
interruption (AC1) signal is output from the output terminal 
of the AND-gate 66 to the interruption controller 40 and the 
VAR 70, due to the ACIA signal being output from the ACXAR 68 
to the AND-gate 66 {FEO ~ 1, FEl = 1 , FE2 = 1) . 
25 Although each of the remaining comparison address data 



38 



from mem 



2000$ 8fi 3B(*)ll:22/18ll:16/iaft4801158873 P 40 



CA3, CA4 f CAS, CA6 and CA7 does not participate in an actual 
revision o£ the ROM-stored programs, each comparison address 
data is stored as a certain 16-bit data in a corresponding 
eomparison-address-storage zone (CAZ3, CAZ4, CAZ5, CAZ6, CAZ7) 
5 of the EEPROM 18. As stated above, when the CPU 10 is powered 
ON, the respective comparison address data CA3 , CA4 , CAS, CA6 
and CA7 are read from the coroparison-address-storage zones 
CAZ3, CAZ4 , CAZ5 , CAZ6 and CAZ7 of the EEPROM 18, and are then 
written in the CAR's 50 of the circuit elements 48 3 , 48 4 , 48 5 , 
JLO 48 6 and 48 7 . Accordingly, in each of the circuit elements 48 3 
! y to 48 7 , an address retrieved from the program counter 26 may 
accidentally coincide with a comparison address data (CA3, 
CA4, CAS, CAS , CA7) held in the CAR 50. Of course, when there 
is the coincidence between the retrieved address and the 
lis comparison address data (CA3, CA4, CA5 , ca6, ca7) , an address- 
er coincidence (AC) signal is output from the address comparator 

52 , resulting in an outputting of an address -coincidence - 
Q inteararuption-retjuiring (ACIR) from the output terminal Q of 
the flip-flop 62- Nevertheless, an address-coincidence*- 
20 interruption (ACI) signal cannot be output from the output 

terminal of the AND-gate 66 to the interruption controller 40 
and the VAR 70, because each of the flag data FE3 , FE4 , FES, 
FE6 and FE7 is *0" in that none of the comparison address data 
CA3, CA4, CAS, CA6 and CA7 participate in an actual revision 
25 of the ROM-stored programs. 
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In each of the circuit elements 48 Q , 48 x and 48 2 , when 
the ACI signal is input from the output terminal of the AND- 
gate 66 to the interruption controller 40, a sequential* 
interruption- transition processing is executed by the CU 20 of 
5 the CPU 10 in accordance with a flowchart as shown in Fig* 21. 
Note, the execution of the sequential-interruption- transition 
processing is automatically carried out, regardless of the 
ROM-stored programs, whenever the ACI signal is input to the 
interruption controller 40. 
10 At step 2101, the address of the program counter 26, 

£ which coincides with the comparison address data (CAO, CA1, 
CA2) , is temporarily stored as a return- address in the stack 
memory area of the RAM 14 {Fig- 12). Then, at step 2102, the 
various flag data (such as the carry flag, the overflow flag, 
s_l5 the zero flag, the sign flag and so on) of the status register 
C] 38 are temporarily stored in the stack memory area of the RAM 
C 14 - Successively, at step 2103, the interruption-allowing 

p flag, held in the status register 38, is made to be "0", 

whereby all the interruptions are prohibited except for a non- 
20 maskable interruption (NMI) and a software interruption, as 
mentioned hereinbefore. 

Note, the processing comprising steps 2101, 2102 and 
2103 is included in a usual sequential-interruption-transition 
processing executed in a conventional microcomputer. 
25 A * step 2104, the vector address data (VA0, VA1, VA2) , 
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held in the VAR 70, is set in the program counter 26 based on 
the outputting of the ACI signal from the 66 to the VAR 70, 
Namely, for example, in the circuit element 48^, when the ACI 
signal is output from the AND -gate 66 to the VAR 70 , the 
5 vector address data VAO is read from the VAR 70 , and is then 
set in the program counter 70. In short/ the address of the 
program counter 26 is renewed by the vector address data (VAO, 
VA1, VA2) , held in the VAR 70. 

In the aforesaid revision examples, as mentioned above, 
10 the respective vector address data VAO, VAl and VA2 correspond 
to the head addresses of the proper , additional and call 
programs stored in the program-storage area of the RAM 14* 
Thus, after the address of the program counter 26 is renewed 
by the vector address data (VAO , VAl , VA2) , the CU 20 makes an 
^15 access to tlxe head address (vector address) of a corresponding 
LP one of the proper, additional and call programs of the RAM 14, 
and thus the corresponding re visional program is executed as 
an interruption processing (step 2105) . 

As soon as the execution of the interruption processing 
20 is started (step 2105), a corresponding flag data (FCO, FCl, 

FC2) held in the ACICR 74 is made to be "1", thereby ou tputting 
the clear signal CI* from the ACICR 74 to the reset circuit 72. 
As stated above, when the clear signal CI* is input as the high 
level signal to the reset circuit 72, the reset signal RE2 is 
25 produced therein, and is then output to the rest terminal R of 
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the flip-flop 62, so that the flip-flop 62 is unlatched, 
whereby the outputting of the ACIR signal from the output 
terminal Q of the flip-flop 62 comes to a standstill. Namely, 
due to the outputting of the reset signal RE2 to the reset 
5 terminal R of the flip-flop 62 F the output level of the output 
terminal Q of the flip-flop 62 is returned from the high level 
to the low level. Thus, the output ting of the ACI signal from 
the output terminal of the M?D-gate 66 to the interruption 
controller 40 also comes to a standstill. On the other hand, 
10 the reset- signal RE3 is also produced in the reset circuit 72, 
i= and is then output to the ACICR 74, whereby the corresponding 
y flag data (FCO, FC1, PC2) is reset to be "0", so that the 

outputting of the clear signal CI* from the ACICR 74 to the 
reset circuit 72 comes to a standstill - 
L^S Figure 22 shows a wiring diagram of the reset circuit 

t; 72. As shown in this drawing, the reset circuit 72 includes a 
J;; first flip-flop 72A, a second flip-flop 72B, an AND-gate 72C 
p. and an OR-gate 72t). The output terminal of the ACICK 74 is 
connected to an input terminal D of the first flip-flop 72A 
20 and one of two input terminals of the AND-gate 72 C, and the 
other input terminal of the AND-gate 72C is connected to an 
inverted output terminal Q (with the bar) of the second flip- 
flop 72B. An output terminal Q of the first flip-flop 72A is 
connected to an input terminal D of the second flip-flop 72B, 
25 and an output terminal of the second flip-flop 72B is 
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connected to one of two input terminals of the OR-gate 72D. 
An output terminal of the AND-gate 72C is connected to the 
reset terminal R of the flip-flop 62, and an output of the OR- 
gate 72D is connected to the input terminal of the ACICR 74. 
5 When the CPU 10 is powered ON, the reset signal is 

input to both reset terminals R of the first and second flip- 
flops 72A and 72B, thereby resetting the first and second 
flip-flop 72A and 72B. Also, the reset signal is input to the 
other input terminal of the OR-gate 72D, and is output as the 
r i0 reset signal RE3 from the output terminal of the OR-gate 72d, 
% whereby the flag data (FCO , FC1, FC2) , held in the ACICR 74, 
is reset to be *0 W . Further, as shown in Fig, 22, the series 
LH of system clock pulses is continuously input: to both input 
|; terminals C of the first and second flip-flop 72A and 72B 
HIS after the CPU 10 is powered OK . 

Figure 23 shows a timing chart of the reset circuit 72 
5f shown in Fig. 22. 

C While the flag data (FCO, FC1, FC2) , held in the acxcr 

74, is *0 H , i.e. while the output level of the ACICR 74 is the 

20 low level, an output level Ql of the output terminal Q of the 
first flip-flop 72A is a low level, as shown in the timing 
chart: of Fig. 23. On the other hand, an output level Q2 of 
the output terminal Q of the second flip-flop 72B is a low 
level, and an output level Q2 (with the bar) of the inverted 

25 output terminal Q (with the bar) of the second flip-flop 72B 
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is a high level. Thus, an output level (R£2) of the AND-gate 
72C is a low level, and an output level (RE3) of the OR-gate 
72D is a low level. 

When the flag data (FCO, FCl, FC2) , held in the ACICR 
5 74, is made to "1% i.e. when the clear signal CL is output as 
the high level signal from the ACICR 74 to the reset circuit 
72, the clear signal CL is input to the AND-gate 72C, whereby 
the reset signal KB2 outputs as the high level signal from the 
output terminal of the AND-gate 72C, as shown in the timing 

10 chart of Fig. 23- Note, at this time, the output level Q2 
(with the bar) of the inverted output terminal Q (with the 
fcazr) of the second flip-flop 72B is the high level. Thus, as 
mentioned above, the flip-flop 62 is unlatched, whereby the 
outputting of the ACIR signal from the output terminal Q of 

as the flip-flop 62 comes to a standstill. 

iff! On the other hand, as shown in the timing chart of Fig, 

23, when the clear signal CL is input to the input terminal D 
of the first flip-flop 72A, the output level Ql of the output 
terminal Q of the first flip-flop 72A is changed from the low 

20 level to a high level in synchronization with a rise of one of 
the system clock pulses, as shown in the timing chart of Fig, 
23. Whan this high level signal (Ql) is input to the input 
terminal D of the second flip-flop 72B, the output level Q2 of 
the output terminal Q of the second flip-flop 72B is changed 
25 from the low level to a high level, and the output level Q 

44 



mumWm ' 200Q£ m 30 (*) ll : 23/111 1:16/Xlft4801 158873 P 46 

(with the bar) of the inverted output terminal Q (with the 
bar) of the second flip-flop 72B is changed from the high 
level to a low level, with both the changes simultaneously 
occurring in synchronization with a rise of one of the system 
5 clock pulses , as shown in the timing chart of Fig, 23. 

Thus, the output level of the AND -gate 72C is returned 
from the high level to the low level, due to the change of the 
output level Q (with the bar) of the inverted output terminal 
Q (with the bar) of the second flip-flop 72B from the high 
10 level to the low level* Namely, the outputting of the reset 
signal RE2 from the AND-gate 72C comes to a standstill. On 
the other hand, the output level of the OR-gate 72D is changed 
from the low level to the high level, due to the change of the 
output level Q2 of the output terminal Q of the second flip- 
Jl5 flop 72B from the low level to the high level. Namely, the 
S reset signal RE3 is output as the high level signal to the 
^ ACIC register 74, as shown in the timing chart of Fig. 23 * 
jr? When the reset signal RE3 is input to the ACICR 74, the 

flag data (FCO, FC1, FC2) is returned from M l* to "0", whereby 
20 the output level of the ACICR 74 to the reset circuit 72 is 
returned from the high level to the low level. Namely, the 
outputting of the clear- signal CI- fzrom the ACICR 74 to the 
reset circuit 72 comes to a standstill. As is apparent from 
the timing chart of Fig, 23, after the outputting of the clear 
25 signal CL from the ACICR 74 to the reset circuit 72 comes to a 
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standstill/ the first flip-flop 72A is unlatched in 
synchronization with a rise of one of the system clock pulses, 
whereby the output level Ql of the output terminal Q of the 
first flip-flop 72A is returned from the high level to the low 
5 level, as shown in the timing chart of Fig. 23. 

Then, after the return of the output level Ql of the 
output terminal Q of the first flip-flop 72A from the high 
level to the low level, the second flip-flop 72B is unlatched 
in synchronization with a rise of one of the system clock 

10 pulses, whereby the output level Ql of the output terminal ft 
of the second flip-flop 72B is returned from the high level to 
the low level, and whereby the output level Q2 (with the bar) 

111 of the inverted output terminal Q (with the bar) of the second 

Rj flip-flop 72A is returned from the low level to the high 

s i5 level , as shown in the timing chart of Fig* 23. 

In short, as explained with reference to the aforesaid 
revision examples, aus soon as the interruption processing is 

u executed for the revision of the ROM- stored programs, due to 
the output ting of the ACI signal from the AND -gate 66 to the 

20 interruption controller 40, the setting of "1" is given to the 
flag data (FCO, FCl, FC2) held in the ACICR 74, whereby the 
outputting of the ACI signal from the AND -gate 66 to the 
interruption controller 40 comes to a standstill. Then, as 
soon as the outputting of the ACI signal from the AND-gate 66 
25 to the interruption controller 40 comes to a standstill, the 
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flag data (FCO, FCl, FC2) , held in the ACICR 74, is returned 
from u l n to "Q\ 

After a completion of the execution of the interruption 
processing based on one of the aforesaid second and third 
5 revision examples (except for the first revision example) , a 
sequential-interruption-re turn processing is executed by the 
CU 20 of the CPU 10 in accordance with a flowchart as shown in 
Fig. 24. 

Note, as stated in detail hereinafter, in the execution 
10 of the interruption processing, a setting of "1" is given to 
% the flag data (FDl, FD2) held in the ACIPR 58, whereby the 
output level of the ACIPR 58 to the inverter 56 is changed 
from the low level to the high level, resulting in a change of 
the output level of the inverter 56 from the high level to the 
,15 low level - 

5; At step 2401, the various flag data, temporarily stored 

in the stack memory area of the RAM 14, are returned to the 
status register 38, and the interruption-allowing flag, held 
in the status register 38, is made to "1", whereby all the 

20 interruptions are again allowed. 

At step 2402, the return-address , temporarily stored in 
the Stack memory area of the RAM 14, is returned to and set in 
the program counter 26. Then, at step 2403, the CU 20 makes 
an access to the return-address of the ROM 12 , indicated by 

25 the program counter 26, whereby a processing is executed based 
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on the ROM- stored programs. 

In the seo^iential-interruption-return processing of 
Fig- 24, when the return- address is set in the program counter 
26 {step 2402) , the AC signal is again output from the address 
5 comparator 52 , because there is the coincidence between the 

return-address and the comparison address data (CAl, CA2) held 
in the CAR 50. Nevertheless, the outputting of the AC signal 
from the address comparator 52 is ignored, because the output 
level of the inverter 56 to the A13D-gate 54 is the low level 
10 due to the flag data (FDl, FD2) being "l". In short, the ACIR 
C signal cannot be output from the output terminal Q of the 
m flip-flop 62. 

On the other hand, when the return-address is set in 
the program counter 26 (step 2402), the AC signal, output from 
f 15 the address comparator 52 , is input to the reset circuit 60. 
Then, when the return-address of the program counter 26 is 
renewed according to an execution of the ROM-stored programs, 
l; the outputting of the AC signal from the address comparator 52 
comes to a standstill, because there is no coincidence between 
20 the renewed address and the comparison address data (CAl, CA2) 
held in the CAR 50. When the outputting of the AC signal from 
the address comparator 52 comes to a standstill, i.e. when the 
output level of the address comparator 52 to the reset circuit 
60 is returned from the high level to the low level, the reset 
25 signal RE1 is produced in the reset circuit 60, and is output 
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to the ACIPR 58, whereby the flag data (FDl, FD2) held in the 
ACIPR 58 is returned from "l" to "O", resulting in a return of 
the output level of the ACIPR 58 to the inverter 56 the high 
level to the low level, 
5 Figure 25 dhows a wiring diagram of the reset circuit 

60. As shown in this drawing, the reset circuit 60 includes a 
first flip-flop 60A, a second flip-flop 60B, an inverter 60C, 
an AND-gate 60D and an OR-gate 60E- The output terminal of 
the address comparator 52 is connected to an input terminal D 
10 of the first flip-flop 60A and an input terminal of the 

^ inverter 60C, and an output terminal Q of the first flip-flop 
60A is connected to an input terminal D of the second flip- 

y} flop 60B. An output terminal of the inverter 60C is connected 
to one of two input terminals of the AND-gate SOD, and the 

:, 15 other input terminal of the AND -gate SOD is connected to an 
output terminal Q of the second flip-flop 60B. An output 

^ terminal of the AND -gat© 60D is connected to one of two input 

if: terminals of the OR-gate 60E, and an output terminal of the 
OR-gate 60E is connected to the input terminal of the ACIPR 
20 58. 

When the CPU 10 is powered 023, the reset signal is 
input to both reset terminals R of the first and second flip- 
flops 60A and 60B, thereby resetting the first and second 
flip-flop 60A and 60B. Also, the reset signal is input to the 
25 other input terminal of the OR-gate 60E, and is then output as 
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the reset signal R£l the output terminal of the OR-gate 60E, 
whereby the flag data (FD1 , FD2) , held in the ACIFR 58, is 
reset to be "0". Further, as shown in Fig. 25, the series of 
system clock pulses is continuously input to both input 
5 terminals C of the first and second flip-flop 6 OA and COB 
after the CPU 10 is powered ON. 

Figure 26 shows a timing chart of the reset circuit 60 
shown in Fig. 25. 

As already mentioned hereinbefore, when the return - 
10 address is set in the program counter 26. during the execution 
of the sequential -interruption-return processing of Fig. 24 
(st:ep 2402) , the AC signal is again output from the SLd&r&ss. 
comparator 52, due to there being the coincidence between the 
return-address and the comparison address data (CA1, CA2) held 

si 5 in the CAR 50, Namely, the output level of the address 

10 comparator 52 is changed from the low level to the high level, 
as shown in the timing chart of Fig, 26, 

S Note, although the AC signal is output from the address 

comparator 52, the ACIR signal eannot be output from the 

2 0 output terminal Q of the flip-flop 62, because the setting of 
"1* given to the flag data (FD1 , FD2) held in the ACIPR 58, as 
stated above. 

"When the AC signal, output from the address comparator 
52, is input to the inverter 60C, an output level INV of the 
25 inverter 60C is changed from a high level to a low level, as 
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shown in the timing chart of Fig. 26. Also, after the AC 
signal is input to the input terminal D of the first flip-flop 
60A, an output level of the output terminal Q of the first 
flip-flop 60A is changed from a low level to a high level in 
5 synchronization with a rise of one of the system clock pulses . 
After this high level signal (Ql) is input to the input 
terminal D of the second flip-flop 60B, an output level Q2 of 
the output terminal Q of the second flip-flop 6 OB is changed 
from a low level to a high level in synchronization with a 
10 rise of one of the system clock pulses, as shown in the timing 
chart of Fig. 26. At this time, an output level of the AND- 
gate 60D is still a. low level, due to the existence of the 
inverter 60C. 

When the return-address of the program counter 26 is 
J 5 renewed according to the execution of the ROM- stored programs, 
s» the outputting of the AC signal from the address comparator 52 
~iz comes to a standstill , because there is no coincidence between 
the renewed address and the comparison address data (CA1, CA2) 
held in the CAR SO. Namely, the output level of the address 
20 comparator 52 is returned from the high level to the low 

level, as shown in the timing chart of Fig. 26. Thus, the 
output level INV of the inverter 60C is returned from the low 
level to the high level, whereby the output level of the AND- 
gata 60D is changed from the low level to a high level, 
25 resulting in an outputting of the reset signal REl from the 
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output terminal of the OR-gate 60E to the ACIPR 58. As stated 
above, when the reset signal REl is input to the ACIPR 58 , the 
flag data (FDl, FD2) held therein is reset to be "0*. 

On the other hand, after the outputting of the AC 
5 signal from the address comparator 52 comes to a standstill/ 
i.e. after the output level of the address comparator 52 to 
the input terminal D of the first flip-flop 60A is returned 
from the high level to the low level, the first flip-flop 60A 
is unlatched in synchronization with a rise of one of the 
10 system clock pulses, resulting in a return of the output level 
Ql of the output terminal Q of the first flip-flop 60A from 
the high level to the low level, as shown in the timing chart 
of Fig. 26. Aftex: the low level signal (Ql) is input to the 
- output terminal Q of the second flip-flop 60B, this second 
15 flip-flop 60B Is unlatched in synchronization with a rise of 
fS one of the system clock pulses, resulting in a return of the 
j. output level Q2 of the output terminal Q of the second flip- 
pi flop BOB from the high level to the low level; as shown in the 

tijaing chart of Fig. 26. Thus, the output level of the AND- 
20 gate 60D is returned from the high level to the low level, 
whereby the outputting of the reset signal REl from the OR- 
gate 60S comes to a standstill. Namely, the output level of 
the OR-gate 60E is returned from the high level to the low 
level . 

25 In short, in the aforesaid second and third revision 
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examples, before the completion of the execution of the 
interruption processing , the setting of "1" is given to the 
flag data (FDl, FD2) held in the ACXPR 58, whereby the 
outputting of the ACIR signal from the output terminal Q of 
5 the flip-flop 62, and therefore, the outputting of the ACI 

signal from the AND-gate 66 is prohibited, notwithstanding the 
outputting of the AC signal from the address comparator 52 due 
to there being the coincidence between the return-address and 
the comparison address data (CA1, CA2) held in the CAR 50. 
10 Then, when the return-address of the program counter 26 is 
I: renewed, the flag data (FD1, PD2) is reset to be "0" due to the 
reset circuit 60 arranged as shown in Fig* 25. 

In the aforesaid first revision example directed to the 
ft case where one of the ROM-stored programs includes bugs, even 
S 15 if the execution of the interruption processing is completed, 
the flag data FDO held in the ACIPR 58 cannot be set to be a V , 
as stated hereinafter, and thus, the sequential -inter naption- 
: return processing (Fig. 24) cannot be executed, because other 

wise the program including the bugs is executed due to the 
20 return-address being returned from the stack memory area of 
the RAM 14 to the program counter 26. Accordingly, in the 
aforesaid first revision example, after the execution of the 
interruption processing is completed, the CU 20 must make an 
access to a suitable address, before the execution of the 
25 program including the bugs can be prevented- Namely, in the 
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aforesaid first revision example, after the execution of the 
interruption processing is completed, such a suitable address 
is set in the program counter 26. 

In the aforesaid first revision example, the various 
5 flag data, temporarily stored in the stack memory area of the 
RAM 14, are utilized during the execution of the interruption 
processing, if necessary, and are otherwise scrapped* Of 
course, the return -address , temporarily stored in the stack 
memory area of the RAM 14, is scrapped. 
10 Note, in the aforesaid second and third revision 

p examples, after the execution of the interruption processing 

is completed, the CU 20 does not necessarily make an access to 
the return-address . Namely, the CO 20 may make an access to a 
suitable address after the completion of the execution of the 

*fe5 interruption processing, similar to the case of the aforesaid 

Lj first revision example, 

figure 27 shows, by way of example , a system operation 
routine for an electronic product, such as a printer, a video 
camera, a digital still camera, an electronic watch and so on, 

20 in which the aforementioned microcomputer is incorporated. 

Note, an execution of the system operation routine is started 
by electrically powering the electronic product ON. 

At step 2701, the CPU 10 is initialized, and then, at 
step 2702, peripheral circuits, included in the electronic 

25 product, are initialized. 
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At step 2703, it is determined whether there is a 
demand for writing revisional programs and various data in the 
EEPROM 18. As already stated hereinbefore, when the EEPROM 18 
cannot be removed from the microcomputer, the microcomputer 
5 (Fig. 1) is oonnected to the EEPROM-writing computer (not 

shown) for writing the revisional programs and various data in 
the EEPROM 18. In this case, a signal for demanding to write 
the revisional programs and various data in the EEPROM 18 is 
output from the EEPROM-writing computer to the CPU 10 of the 
10 mierooomputer. Thus, it is possible to determine whether 
U there is the demand for writing the revisional programs and 
yl various data in the EEPROM 18. 

At step 2703, if it is confirmed that there is the 
demand for writing the revisional programs and various data in 
15 the EEPROM 18, the control proceeds to step 2704, in which the 

EEPROM-writing program, previously stored in the ROM 12 , is 
J executed, whereby the writing of the revisional programs and 
| vari <»« «^ta in the EEPROM 18 is performed under control of 
the EEPROM-writing computer. Of course, when the aforesaid 
20 three revision examples axe incorporated in the ROM-stored 
programs, the proper, additional and call programs, the 
comparison address data CAO, CA1 and CA2, the vector address 
data VAO, VA1 and VA2, and the flag data PEO, PE1 and FE2 are 
written in the EEPROM 18 at step 2704. Also, if necessary, a 
25 writing of various data, such as correction data, for the 
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electronic product in the EEPROM 18 is performed at step 2704. 

When the writing of the revisional programs and various 
data in the EEPROM 18 is completed, i.e. when the EEPROM- 
writing computer is disconnected from the microcomputer, the 
5 control proceeds to step 2705* On the other hand, at step 
2704 , when there is no demand for writing revisional programs 
and various data in the EEPROM 18, i.e. when the microcomputer 
is not connected to the EEFROM-writing computer , the control 
skips over step 2704, and proceeds to step 2705. 
10 In either case, at step 2705, the various data, such as 

D correction data, for the electronic product, are read from the 

fp data-storage area of the EEPROM 18 (Fig- 3) , and are then 
written in the data-storage area of the RAM 14. (Fig. 12) . 

Note, when the EEPROM 18 is removably installed in the 

; 15 microcomputer, the writing of the revisional programs and 

various data in the EEPROM IB is directly performed, using the 
EEPROM- writing computer on which the removed EEPROM 18 is 
mounted, as mentioned hereinbefore. Thus, in this case / steps 
2703 and 2704 are omitted from the system operation routine of 

20 Fig. 27. 

At step 2706, it is determined whether a number of 
bytes to be read from the program- storage area of the EEPROM 
18 {Fig. 3) is zero. If at least one revisional program is 
stored in the program- storage area of the EEPROM 18, there are 
25 a number of bytes corresponding to the stored revisional 
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program. However, if no revisional program is stored in the 
program-storage area of the EEPROM 18 , there is zero number of 
bytes to be read from the program- storage area of the EEPROM 
18- 

5 When the mamber of bytes to be read from the program- 

storage area of the EEPROM 18 is not zero, i.e. when at least 
one revisional program is stored in the program-storage area 
of the EEPROM 18, the control proceeds to step 2707, in which 
the revisional program is read from the program- storage area 
10 of the EEPROM 18, and is then written in the program- storage 
area of the RAM 14. 

At step 2708, the respective comparison address data 
CAO, CA1, • CA6 and CA7 are read from the comparison -address - 
storage zones CAZO, CAZl, - CA26 and CAZ7 of the EEPROM 18, and 

:r»; 

15 are then written in the CAR's 50 of the circuit elements 48 n ; 
the respective vector address data VAO, VA1, •» VA6 and VA7 are 
read from the vector-address- storage zones VA£0, VAZl, »- VA26 
and VAZ7 of the EEPROM 18, and are then written in the VAR's 70 
of the circuit elements 48 n ; and the respective flag data FEO, 

20 FEl, - FE6 and FE7 are read from the eight flag-data-storage 
zones of the EEPROM 18, and are then written in the ACIAR's 68 
of the circuit elements 48 n - Thereafter , at step 2709, various 
processing-routines are executed in accordance with the ROM- 
stored programs . 

25 Of course, at step 2706, if the number of bytes to fc>e 
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read from the program- storage area of the EEPROM 18 is zero, 
i.e. if no revisional program is stored in the program- storage 
area of the EEPROM 18, the control skips steps 2707 and 2708, 
and proceeds to step 2709, 
5 Referring to Fig. 28, a part of a processing-routine to 

be executed in step 2709 of the system operation routine (Fig. 
27) is shown by way of example* As is apparent from Fig. 28, 
the processing-routine includes steps 2801 to 2810, and an 
instruction, stored in the ROM 12 at a given address thereof, 

10 is executed at each step (2801, 2802, - 2809, 2810). In other 
- words, the processing-routine is programed and stored in the 
ROM 12 at given addresses thereof. 

Note, in the microcomputer (Fig. 1), an instruction to 
execute in each step (2801, 2802, »■ 2809, 2810) is composed of 

15 4 bytes, and thus is stored in a 4~byte address (ROM 12) . 

At step 2801, a subroutine A is called and executed. 
An instruction for calling and executing the subroutine A is 

5 stored in a 4 -byte address consisting of, for example, four 
consecutive addresses 9800H to 9803H (ROM 12) , each of which 

20 is composed of one byte. Note, a character "H", appended to 
each four-digit address number, represents that the address 
number is based on the hexadecimal notation. Also, note, a 
head address number of the subroutine A is represented as 
1000H by way of example. 

25 At step 2802, an instruction for discriminating a 
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conditional branch X is executed* This instruction is stored 
in a 4 -byte address consisting of four consecutive addresses 
9804H to 9807H following the address 9803H. 

On assumption that the control proceeds from step 2802 
5 to step 2803 as a result of the discrimination of the 

conditional branch X, a subroutine B is called and executed 
(step 2803) - An instruction for calling and executing the 
subroutine B is stored in a 4-byte address consisting of four 
consecutive addresses 9808B to 980BH following the address 
10 9807H. Kote, a head address number of the subroutine B is 
£ represented as 2000H by way of example. 

yl At step 2804 , a subroutine C is called and executed. 

An instruction for calling and executing the subroutine C is 
R ■ stored in a 4-byte address consisting of four consecutive 
115 addresses 980CH to 980FH following the address 980BH. Note, a 
;S head address number of the subroutine C is represented as 

3000H by way of example. 

At step 2804, after the execution of the subroutine C 

is completed, the control jumps to an optional step "W*\ Of 
20 course, an instruction for making the control jump to the step 
is stored in a 4-byte address consisting of four 

consecutive addresses 9810H to 9813H following the address 

980FH. 

On assumption that the control jumps from step 2802 to 
25 step 2805 as a result of the discrimination of the conditional 
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branch X, an instruction for discriminating a conditional 
branch Y is executed (step 2805) . This instruction is stored 
in a 4-byte address consisting of four consecutive addresses 
9814H to 9817H following the address 9813H. 

On assumption that the control proceeds from step 2805 
to step 2606 as a result of the discrimination of the 
conditional branch Y, a subroutine D is called and executed 
(step 2806) . An instruction for calling and executing the 
subroutine D is stored in a 4-byte address consisting of four 
consecutive addresses 9818H to 981BH following the address 
9817H. Note, a head address number of the subroutine D is 
represented as 4000H by way of example. 

At step 2807, an instruction for discriminating a 
conditional branch Z is executed. This instruction is stored 
in a 4-byte address consisting of four consecutive addresses 
981CH to 981FH following the address 981BH, 

On assumption that the control proceeds from step 2807 
to step 2808 as a result of the discrimination of tke 
conditional branch Z, a subroutine E is called and executed 
(step 2808) . An instruction for calling and executing the 
subroutine E is stored in a 4-byte address consisting of four 
consecutive addresses 9820H to 9823H following the address 
981FHL Note, a head address number of the subroutine E is 
represented as 5000H by way of example. 

At step 2808, after the execution of the subroutine E 
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is completed, the control jumps to the optional step *W . Of 
course, an instruction for making the control jump to the step 
T is stored in a 4-byte address consisting of four 
consecutive addresses 9824H to 9827H following the address 
5 9823H. 

On assumption that the control jumps from step 2807 to 
step 2809 as a result of the discrimination of the conditional 
branch Z, a subroutine F is called and executed (step 2809) . 
An instruction for calling and executing the subroutine F is 
10 stored in a 4-byte address consisting of four consecutive 
"2 addresses 9828H to 982BH following the address 9827H. Note, a 
head address number of the subroutine F is represented as 
6000H by way of example, 
frj At step 2809, after the execution of the subroutine F 

is is completed, the control jumps to the optional step "W". Of 

course, an instruction for making the control jump to the step 
W is stored in a 4-byte address consisting of four 
consecutive addresses 982CH to 982FH following the address 
982BH, 

20 On assumption that the control jumps from step 2805 to 

step 2810 as a result of the discrimination of the conditional 
branch Y, a subroutine G is called and executed (step 2810) , 
An instruction for calling and executing the subroutine G is 
stored in a 4-byte address consisting of four consecutive 

25 addresses 9830H to 9833H following the address 982FH, Note, a 
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head address number of the subroutine G is represented as 
7000H by way of example. 

At step 2810, after the execution o£ the subroutine G 
is completed, the control jumps to the optional step "W*. of 
5 course, an instruction for making the control jump to the step 
"W" is stored in a 4-byte address consisting of four 
consecutive addresses 9834H to 9837H following the address 
9833H. 

Figure 2d conceptually shows relationships between the 
10 addresses successively renewed in the program counter 26 and 
; the instructions executed in steps 2801 to 2810 of the 
processing-routine of Fig. 28- 

During the execution of the processing- routine of Fig. 
j 28, in the microcomputer (Fig. 1), while an instruction stored 
15 in a 4-byte address is decoded by the CO 20, four consecutive 
pieces of 1-byte address are successively renewed in the 
program counter 26. For example, while the four consecutive 
addresses 9800H to 9803H are accessed by the CU 20 to decode 
the instruction for calling and executing the subroutine A, 
20 the addresses 9800H to 9803H are successively renewed in the 
program computer. Thus, while the processing-routine of Fig. 
28 is executed, a 1-byte address is successively renewed in 
the program counter 28 as conceptually shown in Fig. 29. 

On the other hand, the subroutines A, B, C, D , E, F and 
25 G, which are executed in steps 2801, 2803, 2804, 2806, 2808, 
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2809 and 2810, respectively, are stored in the ROM 12 , as 
conceptually shown in Fig. 30. 

As is apparent from Fig. 30, the subroutine A is stored 
as a program composed of a series of instructions in the ROM 

5 12 at the head address 1000H and addresses following the same; 
the subroutine B is Stored as a program composed of a series 
of instructions in the ROM 12 at the head address 2000H and 
addresses following the same; the subroutine C is stored 3S a 
program composed of a series of instructions in the ROM 12 at 

10 the head address 3000H and addresses following the same; the 
subroutine D is stored as a program composed of a series of 
instructions in the ROM 12 at the head address 4000H and 
addresses following the same; the subroutine E is stored as a 
program composed of a series of instructions in the ROM 12 at 

15 the head address 5000H and addresses following the same; the 
subroutine F is stored as a program composed of a series of 
instructions in the ROM 12 at the head address 6000H and 
addresses following the same; and the subroutine G is stored 
as a program composed of a series of instructions in the ROM 

20 12 at the head address 7000H and addresses following the same. 

In the processing-routine of Pig. 28 , for example, if 
there are bugs in the program of the subroutine B, as the 
aforesaid first revision example, a revisional or proper 
program, which should be substituted for the program of the 

25 subroutine B, is prepared and stored in the program- storage 
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area of the EEFROM 18 (step 2704) , At this time, the first 1- 
byte address 9808H of the 4-byte address, in which the 
instruction for calling the subroutine B is stored, is written 
as a comparison address data CAO[CAOq 0 , CA0 01 , -» CA0 x4 , CA0 15 1 
in the comparison -address- storage zone CAZO of the EEPROM 18 . 
Also, a head address (e.g. 0600H) of the proper program, when 
being read from the EEPROM 18 and being stored in RAM 14, is 
written as a vector address VAO[VA0 00 , VA0 01 , •» VA0 14 , VAO^g] 
in the vector-address-storage zone VAZO corresponding to the 
comparison-address-storage zone CAZO . Further, a setting of 
"1* is given to the flag data FEO corresponding to the address 
data CAO and VAO, 

Also, in the processing-routine of Fig. 28, for 
example, if an additional routine should be executed just 
before the execution of the subroutine D, as the aforesaid 
second example, an additional program for the additional 
routine is prepared and stored in the program- storage area of 
the EEPROM 18 (step 2704) . At this time, the first 1-byte 
address 9818H of the 4-byte address, in which the instruction 
for calling tbe subroutine D is stored, is written as a 
comparison address data CA1[CA1 00 , CA1 Q1 , - CA1 14 , CA1 XS } in 
the comparison-address-storage zone CA21 of the EEPROM 18. 
Also, a head address (e.g. 0800H) of the additional program, 
when being read from the EEPROM 18 and being stored in RAM 14 , 
is written as a vector acidxaas VAl[VAl Q0 , VA1 Q1 , - VAl 14 , 
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VAl 15 ] in the vector-address-storage zone VAZ1 corresponding to 
the comparison-address-storage zone CAZ1. Further, a setting 
of M l" is given to the flag data FEl corresponding to the 
address data CA1 and VAl . 
5 Further , in the processing-routine of Fig. 28, for 

example, if the subroutine G should be executed just before 
the execution of the subroutine E, as the aforesaid third 
example, a call program for calling the subroutine G is 
prepared and stored in the program- storage area of the EEPROM 

10 18 (step 2704) . At this time, the first 1-byte address 9820H 
of the 4-byte address, in which the instruction for calling 
the subroutine E is stored, is written as a comparison address 
data CA2[CA2 00 , CA2 Q1/ - CA2 14 , CA2 15 1 in the comparison- 
address -storage zone CAZ2 of the EEPROM 18. Also, a head 

15 address (e.g. 0A00H) of the call program, when being read from 
the EEPRQM 18 and being stored in RAM 14, is written as a 
vector address VA2 [VA2 Q0 , VA2 01 , - VA2 14 , VA2 1S ] in the vector- 
address-storage zone VA22 corresponding to the comparison- 
address-storage zone CA22, Further, a setting of "1* is given 

20 to the flag data FE2 corresponding to the address data CA2 and 
VA2. 

A» stated hereinbefore, during the system operation 
routine of Fig. 27, the proper, additional and call programs 
are read from the program- storage area of the EEPROM 18, and 
25 are written in the program- storage area of the RAM 14 (step 
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2707) . Each o£ these revisional programs is stored as an 
interruption -routine in the RAM 14, as conceptually shown in 
Fig. 31 r In particular/ the proper program is stored as an 
interruption-routine J in the RAM 14 at a series of addresses 
including the head address 0600H, at whieh a first instruction 
of the proper program is stored; the additional program is 
stored as an interruption- routine K in the RAM 14 at a series 
of addresses including the head address 0800H, at which a 
first instruction of the additional program; and the call 
program is stored as an interruption- routine L in the RAM 14 
at a series of addresses including the head address 0A00H, at 
which a first instruction of the call program is stored. 

Also, during the system operation routine of Fig- 27, 
the respective comparison address data CAO, CAl, «. CA6 and CA7 
are read from the comparison-address -storage zones CAZO, CAZ1 , 
- CA26 and CAZ7 of the EEPROM 18, and are then written in the 
CAR's 50 of the circuit elements 48 n ; the respective vector 
address data VAO , VAl, «■ VJt€ and VX7 are read from the vector- 
address-storage zones VAZQ, VAZ1, »- VAZ6 and VA27 of the EEPROM 
18, and are then written in the VAR's 70 of the circuit 
elements 48 n ; and the respective flag data FEO, FEl , - FE6 and 
FE7 are read from the eight flag-data-storage zones of the 
EEPROM 18, and are then written in the ACIAR's 68 of the 
circuit elements 48 n (step 2708) , 

Of course , in this case, the respective comparison 
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address data CAO, CAl and CA2 correspond to the addresses 
9808H, 9818H and 9820H; the respective vector address data 
VAO, VA1 and VA2 correspond to the addresses 0600H, 0800H and 
OAOOH; and the setting of "1" is given to only the flag data 
5 FEO, FE1 and FE2. On the other hand, each of the comparison 
address data CA3, CA4, CAS, CAS and CA7 is held as a certain 
16-bit data in a CAR 50 of a corresponding circuit element 
(48 3 , 48^, 48 5 , 48 g/ 48 ? ) ; each of the vector address data VA3, 
VA4, VA5 f VA6 and VA7 is held as a certain 16 -bit data in a 

10 VAR 70 of a corresponding circuit element (48^, 48^, 48^, 48^, 
48 7 ) ; and the setting of tt 0 H is given to each of the flag data 
FE3, FE4 , PES, FE6 and FE7 . 

An operation of the CPU 10 based on the first revision 
example is explained below, 

15 An address is successively renewed in the program 

counter 26. When a renewed address reaches the first l-fayte 
address 9808H of the 4-byte address at which the instruction 
for calling the subroutine 3 is stored , ±.&. when the renewed 
address 9808H coincides with the comparison address data CAG 

20 held in the CAR 50 of the circuit element 48 Q , an address- 
coincidence (AC) signal is output as a high level signal from 
the address comparator 50 of the circuit element 48 Q , whereby 
an address-coincidence-interruption-reguiring (ACIR) signal is 
output from the output put terminal Q of the flip-flop 62. 

25 Thus / an address-coineidenee-interiruption (ACI) signal is 
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output from the AMD-gate 66 of the circuit element 48 0 , because 
an address-eoincidence-interruption-allowing (ACIA) signal is 
output from the ACIAR 68 to the AND-gate 66 due to the setting 
of u l" being given to the flag data F£0 . 
5 Whan the ACI signal , output from the AND -gate 66 of the 

circuit element 48 Q , is input to the interruption controller 
40, the sequential-interruption-transition processing (Fig. 
21) is executed by the CU 20 of the CPU 10 without making an 
access to the 4-byte address (9808H to 980BH) at which the 

10 instruction for calling the subroutine B is stored- Namely/ 
the address 9808H of the program counter 26 is temporarily 
stored as a ro turn- address in the stack memory area of the RAM 
14 (Fig. 12) , and the various flag data (such as the carry 
flag, the overflow flag, the zero flag, the sign flag and so 

15 on) of the status register 38 are temporarily stored in the 

stack memory area of the RAM 14- Further,, the vector address 
data VAO (0600H) , held in the VAR 70 of the circuit element 
48 Q/ is set in the program counter 26. Thus, an access is made 
by the CU 20 to the head address 0600H of the interrtiption- 

20 routine J, resulting in an execution of the interruption- 
routine J\ 

Note, as stated hereinbefore, in the execution of the 
sequential-interruption-transition processing (Fig. 21), the 
interruption-allowing flag, held in the status register 38, is 
25 made to be "0*, whereby all the interruptions are prohibited 
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except for a non-maskable interruption (MH) and a software 
interruption „ 

In the execution of the interruption-routine J, first, 
at step Jl, a setting of a l H is given to the flag data FCO 
5 (Fig. 13) held in the ACICR 74 of the circuit element 48 Q , and 
thus a clear signal CI* is output from the ACICR 74 to the 
reset circuit 72 . When the clear signal CL is input to the 
reset circuit 72, a reset signal RE2 is output from the reset 
circuit 72 to the reset terminal R of the flip-flop €3 in the 

10 aforesaid manner (E*igs. 22 and 23), whereby the flip-flop 62 
is unlatched so that the output ting of ACIR signal from the 
output terminal Q of the flip-flop 62 comes to a standstill. 
After the outputting of the reset signal RE2 , a reset signal 
RE3 is output from the reset circuit 72 to the ACICR 74, 

15 whereby the flag data FCO of the ACICR 74 is returned from 
to *0 n . 

At step 02 , a revisional routine is executed in 
accordance with the propar program, which is substituted for 
the subroutine B including the bugs. When the execution of 

20 the revisional routine is completed, the control proceeds to 

step J3, in which the various pieces of status information are 
returned. Namely, the various flag data, temporarily stored 
in the stack memory area of the RAM 14, are returned to the 
status register 38 , and the interruption- allowing flag, held 

25 in the status register 38, is made to be "1", whereby all the 
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interruptions are again allowed. Further, at step J3 , the 
return-address, temporarily stored in the stack memory area of 
the RAM 14, is scrapped without being returned to the program 
counter 26. 

5 At step J4, the control jumps to the first 1-byte 

address 980CH of the 4-byte address at which the instruction 
for calling the subroutine C is stored, whereby an access is 
made by the CU 20 to the address 980CH, resulting in an 
execution of the subroutine C. At this time, of course, the 

10 address 980CH is set in the program counter 26. 

Accordingly, after the production of the microcomputer 
(Fig, 1), although bugs are unfortunately found in a program 
of the ROM-stored programs, it is possible to virtually make a 
revision of the program including the bugs, whereby the whole 

15 of t&e ROM-stored programs can properly function. 

An operation of the CKJ 10 based on the second revision 
example is explained below. 

When an address, which is successively renewed in the 
program counter 26, reaches the first 1-byte address 981 8H of 

20 the 4-byte address at which the instruction for calling the 
subroutine D is stored, i*e. when the renewed address 9818H 
coincides with the comparison address data CA1 held in the CAR 
SO of the circuit element 48 1 , an address-coincidence (AC) 
signal ia output as a high level signal from the address 

25 comparator 50 of the circuit element 48 1 , whereby an address- 
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coincidence-interruption-requiring (ACIR) signal is output 
from the output put terminal Q of the flip-flop 62. Thus, an 
address-coincidence- interruption (ACI) signal is output from 
the AND-gate 66 of the circuit element 48 1 , because an address- 
5 coincidence-interruption-allowing (ACIA) signal is output from 
the ACIAR 68 to the AND-gate 66 due to the setting of u l" being 
given to the flag data FE1* 

When the ACI signal, output from the AND-gate 66 of the 
circuit element 4S 1 , is input to the interruption controller 

10 4Q, the sequential-interruption-transition processing (Fig. 
21) is executed by the CU 20 of the CPU 10 without making an 
access to the 4-byte address (9818H to 981BH) at which the 
instruction for calling tha subroutine D is stored* Namely, 
the address 9818H of the program counter 26 is temporarily 

15 stored as a return- address in the stack memory area of the HAM 
14 (Fig- 12) , and the various flag data (such as the carry 
flag, the overflow flag, the zero flag, the sign flag and so 
on) of the status register 38 are temsporajcily stored in the 
stack memory area of the BAM 14* Further, the vector address 

20 data VA1 (0800H) , held in the VAR 70 of the circuit element 

48^, is set in the program counter 26. Thus, an access is made 
by the CV 20 to the head address 0800H of the interruption- 
routine K, resulting in an execution of the interruption- 
routine K. 

25 Note, similar to the first revision example, in the 
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execution of the sequential-interruption-transition processing 
(Fig- 21) , the interruption-allowing flag, held in the status 
register 38 r is made to be *0", whereby all the interruptions 
are prohibited except for a non-maskable interruption (KMX) 
5 and a software interruption. 

In the execution of the interruption -routine K, first, 
at step Kl, a setting of "1" is given to the flag data FC1 
(Fig* 14) held in the ACXCR 74 of the circuit element 48^ and 
thus a clear signal CL is output from the ACICR 74 to the 

10 reset circuit 72. When the clear signal CL is input to the 

reset circuit 72, a reset signal RE2 is output from the reset 
circuit 72 to the reset terminal R of the flip-flop 63 in the 
aforesaid manner (Figs * 22 and 23) / whereby the flip-flop 62 
is unlatched so that the outputting of ACIR signal from the 

15 output terminal Q of the £lip-flop 62 comes to a standstill. 
After the outputting of the reset signal KE2 , a reset signal 
RE3 is output from the reset circuit 72 to the ACICR 74 , 
whereby the flag data FCl of the ACXCR 74 is returned from *l" 
to *0\ 

20 At step K2, si revisional or additional routine is 

executed in accordance with the additional program. When the 
execution of the additional routine is completed, the control 
proceeds to step K3, in which a setting of u l" is given to the 
flag data FD1 held in the ACIPR 58 of the circuit element 48^ 

25 Thereafter, the CU 20 of the CPU 10 executes the 
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sequential-interruption-return processing (Pig. 24) based on 
an interruption-return instruction, which is written as a last 
instruction in the additional program. Namely , the various 
flag data, temporarily stored in the stack memory area of the 
5 RAM 14, are returned to the status register 38, and the 

interruption-allowing flag, held in the status register 38, is 
made to be *1", whereby all the interruptions are again 
allowed. Further, the return -address 9818H, temporarily 
stored in the stack memory area of the RAM 14, is returned to 

10 and set in the program counter 26, resulting in an execution 
of the subroutine D . 

It is to be noted that, when the return-address 9818H 
is returned and set in the program 26, an address -coincidence 
(AC) signal is again output from the address comparator 50 of 

15 the circuit element 48 x , because there is the coincidence 

between the return-address 9818H and the comparison address 
data CA1 held in the CAR 50 of the circuit element 48 x - 
Nevertheless, an output-ting of an address -coincidence* 
interruption-requiring (ACIR) signal from the output put 

20 terminal Q of the flip-flop 62 is prevented, due to the 

setting of u l" being given to the flag data FD1 of the ACIPR 58 
(step K3) . Thus, an outputting of an address-coincidence- 
interruption (ACX) signal from the AND-gate 66 of the circuit 
element 48^ to the interruption controller 40 is prohibited . 

25 Also, as is apparent from the explanation made with 
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reference to Figs. 25 and 26, when the return-address 9818H is 
renewed by the address 9819H in the program counter 26, the 
outputting of the AC signal from the address comparator 50 of 
the circuit element 48^ comes to a standstill, whereby the flag 
5 data FD1 is reset to be "O". 

An operation of the CPU 10 based on the third revision 
example is explained below. 

When an address, which is successively renewed in the 
program counter 26, reaches the first 1-byte address 9820H of 
10 the 4 -byte address at which the instruction for calling the 
subroutine E is stored, i-e* when the renewed address 982 OH 
[ 'Z coincides with the comparison address data CA2 held in the CAR 

50 of the circuit element 48 2 , an address -coincidence (AC) 
signal is output as a high level signal from the address 
4= 15 comparator SO o£ the circuit element 48 2 , whereby an address- 
coincidence-interruption-requiring (ACIR) signal is output 
from the output put terminal Q of the flip-flop 62- Thus, an 
address-coincidence-interruption (ACI) signal is output from 
^* the AND-gate 66 of the circuit element 48 2 / because an address- 

20 coincidence-iiitexrmption-allowing (ACIA) signal is output from 
the ACIAft 68 to the AND-gate 66 due to the setting of "l" being 
given to the flag data FE2 • 

When the ACI signal, output from the AND -gate 66 of the 
circuit element 48^, is input to the interruption controller 
25 40, the sequential-interruption-transition processing (Fig. 
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21) is executed by the CXJ 20 of the CPU 10 without making an 
access to the 4-byte address (9820H to 9823H) at which the 
instruction for calling the subroutine E is stored- Namely , 
the address 982 OH of the program counter 26 is temporarily 
5 stored as a return-address in the stack memory area of the RAM 
14 (Fig. 12) , and the various flag data (such as the carry 
flag, the overflow flag, the zero flag, the sign flag and so 
on) of the status register 38 are temporarily stored in the 
stack memory area of the RAM 14. Further , the vector address 
10 data VA2 (0A00H) , held in the VAR 70 of the circuit element 

48 2 , is set in the program counter 26, Thus, an access is made 
by the CU 20 to the head address 0A00R of the interruption- 
routine It, resulting in an execution of the interruption- 
routine I*. 

15 Note, similar to the first revision example, in the 

execution of the sequential-interruption-transition processing 
(Fig. 21) , the interruption-allowing flag, held in the status 
register 38, is made to be "0", whereby all the interruptions 
are prohibited except for a non-maskable interruption CNMI) 

20 and a software interruption. 

In the execution of the interruption-routine X*, first, 
at step LI, a setting of "1" is given to the flag data FC2 
(Fig. 15) held in the ACICR 74 of the circuit element 48 2 , and 
thus a clear signal d. is output from the ACICR 74 to the 

25 reset circuit 72, When the clear signal CL is input to the 
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reset circuit 72, a reset signal R£2 is output from the reset 
circuit 72 to. the reset terminal R of the flip-flop 63 in the 
aforesaid manner (Figs. 22 and 23) , whereby the flip-flop 62 
is unlatched so that the outputting of ACIR signal from the 
5 output terminal Q of the flip-flop 62 comes to a standstill. 
After the outputting of the reset signal RE2 , a reset signal 
RE3 is output from the reset circuit 72 to the ACXCR 74 , 
whereby the flag data PC2 of the ACICR 74 is returned from "1" 
to «O rt . 

10 At step L2, the subroutine G having the head address 

7000H is called and executed. Vlhen the execution of the 
subroutine G is completed, the control proceeds to step 1*3, in 
which a setting of "1" is given to the flag data FD2 held in 
the ACIPR 58 of the circuit element 48 2 - 

15 Thereafter, the CU 20 of the CPU 10 executes the 

sequential -interruption-return processing (Fig, 24) based on 
an interruption-return instruction, which is written as a last 
instruction in the call program. Namely, the various flag 
data, temporarily stored in the stack memory area of the RAM 

20 14, are returned to the status register 39, and the 

interruption -allowing flag, held in the status register 38, is 
made to be "1", whereby all the interruptions are again 
allowed. Further, the return -address 9820H, temporarily 
stored in the stack memory area of the RAM 14, is returned to 

25 and set in the program counter 26 f resulting in an execution 
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of the subroutine E . 

Not©, similar to the second revision example, when the 
return-address 9820H is returned and set in the program 26, an 
address -coincidence (AC) signal is again output from the 
5 address comparator 50 of the circuit element 48 5 , because there 
is the coincidence between the return-address 9820H and 
the comparison address data CA2 held in the CAR 50 of the 
circuit element 48^, Nevertheless f an outputting of an 
address-coincidence-interruption-requiring (ACIR) signal from 

10 the output put terminal Q of the flip-flop 62 is prevented, 
due to the setting of "1" being given to the flag data FD2 of 
the ACIPR 58 (step L3) . Thus, an outputting of an address* 
coincidence-interruption (ACX) signal from the AN£>-gate 66 of 
the circuit element 48 2 to the interruption controller 40 is 

15 prohibited. 

Also, as is apparent from the explanation made with 
reference to Figs. 25 and 26, when the return-address 9820H is 
renewed by the address 9821H in the program counter 26, the 
outputting of the AC signal from the address comparator 50 of 

20 the circuit element 48 2 comes to a standstill, whereby the flag 
data FD2 is reset to be "0". 

Although the ACIMR 64 does not directly participate in 
the revision of the ROM-stored programs, this register (ACXMR) 
can be advantageously utilised for, for example, debugging the 

25 ROM-stored programs- In particular, before the debugging of 
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the ROM-stored programs is performed, eight addresses are 
suitably selected from the addresses of ROM-stored programs, 
and are written in the ACR's 50 of the circuit elements 48 n , 
respectively. During the performance of the debugging of the 
5 ROM-stored programs, it is monitored whether each of the eight 
flag data FMO , EMI , - FM6 and FM7 held in the eight ACIMR's 64 
is changed from "O* to **l n . Thus, it is possible to easily and 
speedy confirm whether an access is made by the CU 20 of the 
CPU 10 to each of the suitably-selected addresses, resulting 

10 in a facilitation of the performance of the debugging of the 

ROM-stored programs. Of course, during the performance of the 
debugging of the ROM-stored programs, a setting of "0" is given 
to all the flag data FEO, FE1, »• FES and FE7 of the ACIAR's 68, 
thereby prohibiting an address-coincidence-interruption (ACI) 

15 signal from each of the AND-gates 66 of the circuit elements 

Figure 32 shows a modification of the circuit element 
(48 n ) representatively shown in Fig, 2. In this modification, 



20 



each of the eight circuit elements 48^ includes an address 



latch circuit 76, through which the address comparator 52 is 
connected to an address bus extending to the program counter 
26. An address, which is successively renewed by the program 
counter 26, is retrieved from the address bus by the address 
latch circuit 76, and the retrieved address is then output to 
25 the address comparator 52, In short, except for this regard, 
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the modification of Fig, 32 is substantially identical to the 
circuit element (48 n ) shown in Fig 2 . 

Figure 33 representatively shows one of eight circuit 
elements 80 n used in a second embodiment of the microcomputer 
5 according to the present invention. Namely, in the second 

embodiment of the present invention, the address-coincidence- 
interruption controller (ACIC) 48 , shown in Fig . 1 , comprises 
the circuit elements 80 Q , 80 iy «• 80 6 and 80^ , which are 
substantially identical to each other. Note, in Fig. 33, the 
10 features similar to those of Fig. 2 are indicated by the same 
references . 

similar to the first embodiment, the number of the 
circuit elements B0 n corresponds to a number of optional 
locations, at each of which the ROM-stored programs should be 
15 revised. Thus, in the second embodiment , it is possible to 
revise the ROM-stored programs at eight optional locations 
thereof . 

Also; in the second embodiment, the CPU 10 features a 
vector-address-texnporary register (VATR) 78, which forms a 
20 part of the ACIC 48, and which is connected to the vector- 
address registers (VAR) 70 o£ the circuit elements 80 . Tne 

n 

VATR 78 is formed as a 16-bit register, the bit-number of 
which is equal to that of an address of the ROM 12. The VATR 
78 is suitably connected to the elements of the microcomputer 
25 via a control bus, an address bus and a data bus, as shown in 
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Fig. 33/ and is initialized by a reset signal when the CKJ 10 
is powered ON. 

In the second embodiment, revisions can be made in the 
ROM- stored programs in stabs tan tially the same manner as the 
first embodiment, except that a sequential-interruption- 
transition processing is executed in accordance with a flow 
chart, as shown in Fig* 34, whenever an address -coincidence- 
interruption (ACI) signal is input from the MTO-gate 66 to the 
interruption controller 40, Thus, in the second embodiment, 
the aforesaid first, second and third revisions, explained 
with reference to Figs. 28 and 29, may be incorporated in the 
ROM-stored programs provided that an interruption-processing 
subroutine M is previously stored as a program composed of a 
series of instructions in the ROM 12 at a head address (e.g. 
8000H) and addresses following the same, as shown in Fig. 35. 

In the second embodiment, an operation of the CPU 10 
based on the first revision example is explained below. 

An address is successively renewed in the program 
counter 26- When a renewed address reaches the first 1-byte 
address 9808H of the 4-byte address at which the instruction 
for calling the subroutine B is stored, i.e. when the renewed 
address 9808H coincides with the comparison address data CAO 
held in the CAR 50 of the circuit element 80 Q/ an address- 
coincidence (AC) signal is output as a high level signal from 
the address comparator 50 of the circuit element 80q, whereby 
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an address-coincidence-interruption-requirin^ (ACIR) signal is 
output from the output put terminal Q of the flip-flop 62 - 
Thus, an address -coincidence- interruption (ACI) signal is 
output from the AHD-gate 66 of the circuit element 80 Q , because 
5 an address-coincidence- in terruption-allowing (AC1A) signal is 
output from the ACXAR 68 to the AND-gate 66 due to the setting 
of a l" being given to the flag data FEO, 

When the ACI signal, output from the AND-gate 66 of the 
circuit element 80 0 , is input to the interruption controller 
10 40, the sequential-interruption-transition processing (Fig. 
34) is executed by the CU 20 of the CPU 10 without making an 
access to the 4-byte address (9808H to 980BH) at which the 
•i instruction for calling the subroutine B is stored. 

In particular, at step 3401, an address of the program 
jp 15 counter 26, and therefore, the address 9808H is temporarily 
r stored as a return-address in the stack memory area of tbe RAM 

J£ 14. Then, at step 3402, and the various flag data (such as 

~ th.e carry flag, the overflow flag, tbe zero flag, the sign 

D flag and so on) of the status register 38 are temporarily 

20 stored in the stack memory area of the RAM 14, Further, at 

step 3403, the interruption-allowing flag, held in the status 
register 38, is made to be "0", whereby all the interruptions 
are prohibited except for a non-maskable interruption (NMI) 
and a software interruption. 
25 At step 3404, the vector address data VA0 (0600H) , held 
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in the VAR 70 of the circuit element 80 Q/ is set in the VATR 
78, due to the ACI signal being input from the AHD-gate 66 to 
the VAR 70 of the circuit element 80 Q . Then, at step 3405, a 
vector address, corresponding to the address-coincidence- 
5 interruption concerned, is selected from an interruption- 
vector area defined, in the ROM 12, and is then set in the 
program counter 26. Namely, the head address 8000H of the 
program of the interruption-processing subroutine M (Fig. 35) 
is set as the vector address in the program counter 26. Note, 

10 various vector addresses are stored in the interruption-vector 
area of the ROM 12. 

When the vector address 8000H is set in the program 
counter 26, an access is made to the vector address 8000H by 
the CU 20 of the CPU 10 (step 3406) , whereby the control jumps 

15 to the vector address 8000H, resulting in an execution of the 
interruption-processing subroutine M. 

As shown in Fig. 35, in the interruption-processing 
subroutine H, an instruction for making the control jump to a 
vector address set in the vector-address-temporary register 

20 (VATR) 80 is executed, whereby the address of the program 

counter 26 is renewed by the vector address . Namely , in this 
first revision example, the vector address VA0 (0600H) , held 
in the VATR 80, is set in the program counter 26. Thus, an 
access is made to the head address 0600H of the interruption- 

25 routine J by the CU 20, resulting in an execution of the 
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interruption-routine or, Namely, the revisional routine is 
executed in accordance with the proper program (step J2) , 
which is substituted for the subroutine B including the bugs* 
After the execution of the interruption-routine J, the 
5 control s^ps to the first 1-byte address 980CH of the 4-byte 
address at which the instruction for calling the subroutine C 
is stored , whereby an access is made by the CU 20 to the 
address 980CH, resulting in an execution of the subroutine C. 
At this time/ of course, the address 980CH is set in the 

10 program counter 26. 

In short, similar to the first embodiment , after the 
production of the microcomputer {Fig- 1), although bugs are 
unfortunately found in a program of the ROM-stored programs, 
it is possible to virtually make a revision of the program 

15 including the bugs, whereby the whole of the ROM-stored 
programs can properly function • 

In the second embodiment, an operation of the CPU 10 
based on the second revision example is explained below. 

When an address, which is successively renewed in the 

20 program counter 26 , reaches the first 1-byte address 9818H of 
the 4 -byte address at which the instruction for calling the 
subroutine D is stored, i.e. when the renewed address 9818H 
coincides with the comparison address data CA1 held in the CAR 
50 of the circuit element 80^, an address-coincidence (AC) 

25 signal is output as a high level signal from the address 
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comparator 50 of the circuit element 80^ whereby an address- 
coincidence^interrniption-requiring (ACIR) signal is output 
from the output put terminal Q of the flip-flop 62, Thus, an 
address-coincidence-interruption (ACI) signal is output from 
5 the AND-gate 66 of the circuit element 80 17 because an address- 
eoincidence-interruption-allowing (AC1A) signal is output from 
the ACXAR 68 to the AND-gate 66 due to the setting of "1" being 
given to the flag data FE1 . 

When the ACI signal, output from the AND-gate 66 of the 
10 circuit element B0 1 , is input to the interruption controller 

O 40, the sequential-interruption-transition processing (Fig. 

PI 34) is executed by the CtJ 20 of the CPU 10 without making an 

access to the 4-byte address (9818H to 981BH) at which the 

^ instruction for calling the subroutine D is stored. 

^ 15 Similar to the above mentioned case, at step 3401, an 

O address of the program counter 26, and therefore, the address 

9818H is temporarily stored as a return-address in the stack 
memory area of the RAM 14* Then, at step 3402, and the 
various flag data (such as the carry flag, the overflow flag, 
20 the zero flag, the sign flag and so on) of the status register 
38 are temporarily stored in the stack memory area of the RAM 
14, Further, at step 3403, the interruption- allowing flag, 
held in the status register 38, is made to be "0", whereby all 
the interruptions are prohibited except for a non-maskable 
25 interruption (KMX) and a software interruption. 
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At step 3404, the vector address data VA1 (0800H) , held 
in the VAR 70 of the circuit element 80 1; is set in the VATR 
78, due to the ACI signal being input from the AND-gate 66 to 
the VAR 70 of the circuit element 80 x , Then, at step 3405, a 
5 vector address, corresponding to the address -coincidence- 
interruption concerned, is selected from the interruption- 
vector area defined in the ROM 12, and is then set in the 
program counter 26. Namely, the head address 8000H of the 
program of the interruption-processing subroutine M (Fig. 35) 

10 is set as the vector address in the program counter 26. Mote, 
various vector addresses are stored in the interruption-vector 
area of the ROM 12 . 

When the vector address 8000H is set in the program 
counter 26, an access is made to the vector address 8000H by 

15 the CU 20 of the CPT? 10 (step 3406) , whereby the control jumps 
to the vector address 8000H, resulting in an execution of the 
interruption -processing subroutine M. 

As shown in Pig, 35, in the interruption-processing 
subroutine M, an instruction for making the control jump to a 

20 vector address set in the vector-address -temporary register 
(VATR) 80 is executed, whereby the address of the program 
counter 26 is renewed by the vector address. Hamely, in this 
second revision example, the vector address VAl (0800H) , held 
in the VATR 80, is set in the program counter 26. Thus, an 

25 access is made to the head address 0800H of the interruption- 
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routine K by the CU 20, resulting in an execution of the 
interruption-routine K. 

After the execution of the interruption-routine K, the 
sequential-interruption-return processing (Fig. 24) is 
5 executed in substantially the same manner as mentioned above. 
Thus, the ROM-stored programs are virtually revi$ed such that 
the ravisional or additional routine (step K2) is executed in 
accordance with the additional program just before the 
execution of the subroutine D. 

10 In the second embodiment, an operation of the CHJ 10 

based on the third revision example is explained below. 

When an address , which is successively renewed in the 
program counter 26, reaches the first 1-byte address 9820H of 
the 4 -byte address at which the instruction for calling the 

15 subroutine E is at>o*:*d. f i.e. when the renewed address 9 82 OH 

coincides with the comparison address data CA2 held in the CAR 
50 of the circuit element 80 £ , an address-coincidence (AC) 
signal is output as a high level signal from the address 
comparator 50 of the circuit element 8O2, whereby an address- 

20 coincidenee-iixterruption-re<juiring (ACIR) signal is output 

from the output put terminal Q of the flip-flop 62. thus, an 
address-coincidence-interruption (ACI) signal is output from 
the AND-gate 66 of the circuit element 80 2 , because an address- 
coincidence-interruption-allowing (ACIA) signal is output from 

25 the ACIAR 68 to the AND-gate 66 due to the setting of u l n being 
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given to the flag data FE2 . 

When the ACI signal, output from the AND -gate 66 of the 
circuit element 80 2 , is input to the interruption controller 
40, the sequential-interruption-transition processing (Fig. 
34) is executed by the CU 20 of the CPU 10 without making an 
access to the 4-byte address (9820H to 9823H) at which the 
instruction for calling the subroutine E is stored. 

Similar to the above mentioned case, at step 3401, an 
address of the program counter 26, and therefore, the address 
9820H is temporarily stored as a return-address in the stack 
memory area of the RAM 14. Then, at step 3402, and the 
various flag data (such as the carry flag, the overflow flag, 
the zero flag, the sign flag and so on) of the status register 
38 are temporarily stored in the stack memory area of the BAM 
14. Further, at step 3403, the interruption-allowing flag, 
held in the status register 38, is made to be M Q\ whereby all 
the interruptions are prohibited except for a non-maskable 
interruption (KMX) and a software interruption. 

At step 3404, the vector address data VA2 (OAOOH) , held 
in the VAR 70 of the circuit element 80 2 , is set in the VATR 
78, due to the ACI signal being input from the AND-gate 66 to 
the VAR 70 of the circuit element 80 2 . Then, at step 3405, a 
vector address, corresponding to the address-coincidence- 
interruption concerned, is selected from the interruption- 
vector area defined in the ROM 12, and is then set in the 
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program counter 26. Namely, the head, address 8000H of the 
program of the interruption -processing subroutine M (Fig- 35) 
is set as the vector address in the program counter 26. Note, 
various vector addresses are stored in the interruption-vector 
5 area of the ROM 12. 

When the vector address 8 00 OH is set in the program 
counter 26, an access is made to the vector address 8000H by 
the CU 20 of the CPU 10 (step 3406) , whereby the control jumps 
to the vector address 80G0H, resulting in an execution of the 

10 interruption-processing subroutine M. 

As shown in Fig- 35, in the interruption-processing 
subroutine M, an instruction for making the control jump to a 
vector address set in the vector-address -temporary register 
(VATR) 80 is executed, whereby the address of the program 

15 counter 26 is renewed by the vector address. Namely, in this 
third revision example, the vector address VA2 (OAOOH) , held 
in the VMTR 80, is set in the program counter 26. Thus, an 
access is made to the head address 0A00B of the interruption- 
routine K by the CU 20, resulting in an execution of the 

20 interruption-routine L. 

After the execution of the interruption-routine L, the 
sequential-interruption-return processing (Fig. 24) is 
executed in substantially the same manner as mentioned above. 
Thus, the ROM-stored programs are virtually revised such that 

25 the subroutine G (step L2) is executed just before the 
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execution of the subroutine £ . 

In the aforesaid second embodiment , the interruption- 
processing subroutine M may includes a step in which all the 
flag data FCO, FCl, »■ FC6 and FC7 of the ACICR's of the circuit 
5 elements 80 n are made to be d l". Of course, when this step is 
included in the interruption-processing subroutine M, it is 
possible to omit the respective steps Jl, Kl and LI from the 
interruption-routines J, K and I*, 

Figure 36 shows a modification of the circuit element 

10 O0 n ) representatively shown in Fig. 33, Similar to the 

modification of Fig. 32, in the modification of the second 
embodiment/ each of the eight circuit elements 80 n includes an 
address latch circuit 76, through which the address comparator 
52 is connected to an address bus extending to the program 

15 counter 26, An address, which is successively renewed by the 
program counter 26, is retrieved from the address bus by the 
address latch circuit 76, and the retrieved address is then 
output to the address comparator 52 • In abort, except for 
this regard, the modification of Fig. 36 is substantially 

2 0 identical to the circuit element (80 n ) shown in Fig 33, 

Although the first, second and third revision examples 
are referred to in the foregoing, another type of revision may 
be incorporated in the ROM-stored programs. For example, the 
ROM-stored programs may be revised such that one of the ROM- 

25 stored pxocfxams is prevented from being executed. 
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As is apparent from the foregoing, in the microcomputer 
according to the present invention, it is possible to make a 
revision in an optional location of programs stored in a ROM 
thereof- Thus, not only can a great flexibility be given to a 
5 design ©£ a microcomputer, but also a cost for production of 
microcomputers can be considerably lowered. 

Finally , it will be understood by those skilled in the 
art that the foregoing description is of preferred embodiments 
of the invention, and that various changes and modifications 
10 may be made to the invention without departing from the spirit 
and scope thereof. 

The present disclosure relates to subject matters 
contained in Japanese Patent Application No. 11-226584 (filed 
on August 10, 1999) which is expressly incorporated herein , by 
15 reference, in its entirety. 
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CLAIMS 

1 , A microcomputer including a read-only memory that 
stores programs, a controller/calculator that successively 
accesses to addresses of the programs stored in said read-only 
memory to retrieve and decode an instruction from each of the 
accessed addresses , thereby executing a processing based on 
the decoded instruction/ and a program counter in which an 
address to be accessed by said controller/calculator is 
successively renewed and indicated, said microcomputer 
comprising: 

at least one comparison-address-storage device that 
stores a comparison address data corresponding to an optional 
address of the programs stored in said read-only memory, at 
which an interruption-processing should be executed to 
virtually revise the programs stored in said read-only memory; 

a random-access memory that stores a revisional program 
in which said interruption-processing is programed; 

at least one vector-address -storage device that stores 
a vector address data corresponding to a head address of said 
revisional program stored in said random- access memory; and 

an address comparator that compares said comparison 
address data with an address successively renewed in said 
program counter, 

wherein said controller/calculator makes an access to 
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the head address of said revisional program, stored in said 
random-access memory, corresponding to said vector address 
data stored in said vector-address-storage device, when it is 
determined by said address comparator that there is a 
coincidence between said comparison address data and the 
renewed address of said program counter, resulting in an 
execution of said interruption-processing in accordance with 
said revisional program. 

2. A microcomputer as set forth in claim 1, further 

comprising : 

a discrimination system that discriminates whether the 
coincidence between said comparison address data and the 
renewed address of said program counter is proper; and 

an address -coincidence-disabling system that disables 
the coincidence between said comparison address data and the 
renewed address of said program counter- 
s' A microcomputer as set forth in claim 1, further 
comprising : 

a rewritable and non-volatile memory that stores said 
revisional program, said comparison address data and said 
vector address data; 

a reading/ writing system that reads said revisional 
program, said comparison address data and said vector address 
data from said rewritable and non-volatile memory, and then 
writes these data in said random-access memory , said 
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comparison-address-storage device and said vector-address- 
storage device, respectively, whenever the microcomputer is 
powered ON. 

4* A microcomputer as set fort* in claim 1, wherein 
said address comparator is connected to said program counter 
to thereby retrieve the renewed address therefrom- 

5. A microcomputer as set forth in claim 1, wherein 
said address comparator is connected to an address bus 
extending to said program counter, to thereby retrieve the 
renewed address therefrom. 

6. A microcomputer as set forth in claim 1, further 
comprising a vector-address data setting system that reads the 
vector address data from said vector-address-storage device, 
and is then set in said program counter, whereby the access to 
the head address of said re visional program by said 
controller/calculator is made, resulting in the execution of 
said interruption-processing in accordance with said 
revisional program. 

7. A microcomputer as set forth in claim 1, further 
comprising: 

a vector-address-tenrporary-storage device that receives 
the vector address data from said vector-address -storage 
device, when it is determined by said address comparator that 
there is the coincidence between said comparison address data 
and the renewed address of said program counter; and 
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a vector -address data setting system that reads the 
vector address data from said vector*- address- temporary-storage 
device, and is then set in said program counter, whereby the 
access to the head address of said revisional program by said 
5 controller /calculator is made, resulting in the execution of 
said interruption-processing in accordance with said 
revisional program. 

8 . A microcomputer as set forth in claim 1 , further 
comprising : 

10 a return- address -setting system that sets said 

comparison address data as a return -address data in said 
program counter when the execution of said interruption- 
processing in accordance with said revisional program is 
completed; and 

15 an address -coincidence-disabling system that disables 

the coincidence between said comparison address data and said 
return-address set in said program counter by said return- 
address-setting system. 
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MICROCOMPUTER WITH PROGRAM-REVISION ABILITY 

ABSTRACT OF THE DISCLOSURE 

A microcomputer has a ROM with pre-stored programs, a 
RAM storing a- revision program for executing an interruption- 
processing, and a program counter in which an address is 
successively renewed during an execution of the ROM-stored 
programs. A first register stores a comparison address 
corresponding to an optional address of the ROM-stored 
programs , at which an interruption-processing should be 
executed to virtually revise the ROM- stored programs, A 
second register stores a vector address data corresponding to 
a head address of the revision program. An address comparator 
compares the comparison address data with a renewed address of 
the program counter. A controller /calculator makes an access 
to the head address of the revision program, corresponding to 
the vector address data of the second register, when there is 
a coincidence between the comparison address data and the 
renewed address of the program counter, resulting in an 
execution of the interruption-processing in accordance with 
the revision program. 
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Declaration and Power of Attorney For Utility or Design Patent Application 

Japanese Language Declaration 



lot c : 



As a below named Inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated 
below next to my name. 

i believe I am the original, first and sole inventor fit only one name is 
listed below) or an orig»nal, first and joint inventor fit plural names 
are listed below) of the subject matter which is claimed and for 
which a patent is sought on the invention entitled 

IfflCROCCMPUIER WITH PROGRAM- REVISION ABILITY 



□91 „ Br=ai«aM7 

ui^k»u^w toasts. 

fc^*ll&»»5S5gSll9afe(a-d)*Zii*365*(b^*iC#-?<: , T 



The specification of which 

(check one) 

S3 is attached hereto. 

□ was filed on as 

Application No. _ 

and was amended on ____ _______ 

(if applicable) 

i hereby state that I have reviewed and understand the contents of 
the above identified specification, including the claims, as amended 
by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to 
the examination of this application in accordance with Title 37, Code 
of Federal Regulations. §1.56. 

I hereby claim foreign priority benefits under Title 35, United States 
Code §H9(a-d) or §365{b) of any foreign application^} for patent 
or inventor's certificate, or §365{a) of any PCT international 
application which designated at least one country other than the 
United States of America, listed below and have also identified 
below, by checking the H No" box. any foreign application for patent 
or inventor's certificate, or of any PCT international application having 
a tiling date before that of the application on which priority is ciaimed: 



Prior foreign applications 
Pll-226584 



(Number) 



Japan 



10/August/1999 



(Number) 


{Country) 


(Day/Month/Year Red) 
BB) 




(Number) 


(Country) 


(Day/Month/Year Filed) 





(Country) 



Priority claimed 
□ 



(Day/Month/rear Filed) 



Yes 

□ 
Yes 

O 

Y«s 
*0 



No 

□ 
NO 

□ 

No 

ft t 
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Japanese Lan^fjage Utility or Design Patent Application Declaration 

□ *(?DAowa^A***tt^^i6*(»fcM(-T£«+*, □ Additional foreign application numbers are listed on a 

supplemental prionty sheer attached hereto. 



i hereby claim the benefit under Title 35, United States Code § 1 1 9(e) 
of any United States provisional appfication(s) listed below, 



(Number} 



fDay/Month/Year Filed) 



(Number) 



(Day/MonthA'ear Red) 



(Number) 



(Day/Momh/Year Red) 



(c) **i < ^^Hl * »« U fcFCTSB£iiJffioffl5 3E* L . * 

" Z. (Application No.) (Dsy/MonthA' ear Filed) 

(Application Mo.) " (Day/Month/Year Filed) 



□ Additional orovisional application numbers are listed on a 
supplemental prion ty sheet attached hereto. 

i hereby claim the benefit under Title 35, United States Code §120 
of any United States applications), or §365{c) of any PCT 
international application designating the United States of America, 
listed below and, insofar as the subject matter of each of the claims 
or this application is not disciosea in the prior United States or PCT 
international application in the manner provided by the first 
paragraph of Title 35, United States Code §112, 1 acknowledge the 
duty to disclose information which is material to patentability as 
denned in Title 37, Code of Federal Regulations §1 .56 which became 
available between the filing date of the prior application and the 
national or PCT international filing date of this application. 



(Status) 

(patented, pending, abandoned) 



(Status) 

(patented, pending, abandoned) 



Art'< . ftl= L ir ftO^BB#a±* 5 1 Mitfe Aft2S« 6 OiffTjs' 



□ Additional U.S. or international application numbers are iisted 
on a supplemental priority sheet attached hereto. 

I hereby declare that all statements made herein of my own 
knowledge are true and that ail statements made on information 
and belief are beiieved to be true; and further that these statements 
were made with the knowledge that wtiiful false statements and the 
like so made are punishable by fine or imprisonment, or both, under 
Section 1001 of Title 16 of the United States Code and that such 
willful false statements may jeopardize the validity of the application 
or any patent issued thereon 

The undersigned hereby authorizes the U.S. attorney or agent 
named herein to accept and follow instructions from either his foreign 
patent agent or corporate representative, if any, as to any action to 
be taken in the Patent and Trademark Office regarding this 
application without direct communication between the U.S. attorney 
or agent and the undersigned in the event of a change in the 
persons from whom instructions may be taken, the U.S. attorney 
or agent named herein will be so notffied by the undersigned. 
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Japanese Language Utility or Design Patent Application Declaration 



7055 

Neil F. Greenblum 
Bruce H. Bernstein 
Roger P. Glass 
James L. Rowland 
Arnold Turk 



POWER OF ATTORNEY: As a named inventor, ! hereby appoint 
the attorney(s) and/or agent(s) associated with the Customer 
Number provided below to prosecute this application and 
transact all business in the Patent and Trademark Office 
connected therewith, and direct that aii correspondence be 
addressed to that Customer Number 

CUSTOMER NUMBER 7055 
The appointed attorneys presently include: 

Reg. No 2B.394 
Reg. No. 29.027 
Reg. No. 30,841 
Reg. No. 32.674 
Reg. No. 33.094 



Address: GREENBLUM & BERNSTEIN, PLC, 

1941 ROLAND CLARKE PLACE 
RESTON. V A 20191 



Direct Telephone Calls to: {name and telephone number) 



GREENBLUM & BERNSTEIN, P.L-C. 

(703)716-1191 





Full name of sole or first inventor 
Hixoyuki TAKAHASHX 




Inventor's signature - * Dare 




Residence 

Tochigi, Japan 




Citizenship 
Japan 




Post Office Address 

C/O ASAHI KOGMCU KOGYO KABUSHIKI KAISHZV 




36-9, Maencx^io 2-chcme, 
Itabashi~ku, Tokyo, Japan 




Full name of second joint inventor, if any 




Second Inventor's signature Dale 




Residence 




Citizenship 




Post Office Address 







(^ifctt^tLJWW^HR^catur ftiat»&1»<8 (Supply Similar information and signature for third and 

J:t>*Sfi fcfiW+S :t.) subsequent joint inventors.) 
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